> 웹 프론트엔드 > JS 튜토리얼 > AngularJS Promise와 함께 콜백을 사용해야 할까요?

AngularJS Promise와 함께 콜백을 사용해야 할까요?

Barbara Streisand
풀어 주다: 2024-11-09 20:22:02
원래의
851명이 탐색했습니다.

Should You Use Callbacks with AngularJS Promises?

AngularJS의 콜백 반전: 안티 패턴

AngularJS에서는 Promise를 반환하는 서비스에 콜백 함수를 전달하는 것이 일반적입니다. 그러나 이 접근 방식은 안티 패턴을 도입하여 Promises의 이점을 방해할 수 있습니다.

안티 패턴 예:

getTokens 서비스가 허용하는 다음 코드를 고려하세요. 콜백 함수:

...
getTokens: function(callbackFn) {
  $http.get('/api/tokens').then (function onFulfilled(response) {
    callbackFn(response.data);
  });
}
...
로그인 후 복사

이 접근 방식에는 몇 가지 단점이 있습니다.

  • 제어 반전: 콜백 함수는 서비스 컨텍스트 내에서 실행되어 제어 흐름을 반전시킵니다. 코드를 따르기가 어려워집니다.
  • 깨진 약속 연결:콜백은 여러 이벤트를 처리하거나 데이터를 순서대로 조작하기 위해 약속이 연결되는 것을 방지합니다.
  • 복잡성: 콜백을 명시적으로 처리하면 코드베이스에 불필요한 복잡성이 추가됩니다.

모범 사례를 위한 리팩토링:

이 안티패턴을 해결하려면, 다음과 같이 코드를 리팩터링합니다.

...
getTokens: function() {
  return $http.get('/api/tokens');
}
...
로그인 후 복사

호출 모듈에서 반환된 Promise를 사용하여 결과를 처리합니다.

yourModule.getTokens()
  .then(function(response) {
    // handle it
  });
로그인 후 복사

모범 사례의 이점:

이 모범 사례를 채택하면 여러 가지 이점이 있습니다.

  • Promise Chaining 유지: 이제 Promise를 연결하여 여러 작업을 순차적으로 수행할 수 있으므로 코드 가독성과 유지 관리성이 향상됩니다.
  • 단순화된 코드: 명시적인 콜백 처리를 제거하면 코드베이스가 단순화되고 잠재적인 오류가 제거됩니다.
  • 향상된 테스트 가능성: Promise는 테스트를 위한 깔끔한 인터페이스를 제공합니다. 비동기 작업을 통해 코드 동작을 더 쉽게 확인할 수 있습니다.

위 내용은 AngularJS Promise와 함께 콜백을 사용해야 할까요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿