> 웹 프론트엔드 > JS 튜토리얼 > Promise.reject를 사용해야 하는 경우와 JavaScript Promise에서 오류를 발생시키는 경우는 언제인가요?

Promise.reject를 사용해야 하는 경우와 JavaScript Promise에서 오류를 발생시키는 경우는 언제인가요?

DDD
풀어 주다: 2024-10-23 22:28:30
원래의
340명이 탐색했습니다.

When to Use Promise.reject vs. Throwing an Error in JavaScript Promises?

Promise.reject와 JavaScript에서 오류 발생의 차이점 이해

Promise.reject와 JavaScript 내에서 오류 발생 Promise는 Promise의 실행을 종료하고 실패를 알리는 목적입니다. 두 가지 방법 모두 본질적으로 동일한 결과를 달성하지만 한 가지 방법이 더 적합한 것으로 판명되는 특정 시나리오가 있습니다.

Promise.reject

Promise.reject() 방법은 명시적으로 거부합니다. .catch() 또는 .then(null,jectHandler) 핸들러가 실행되도록 하는 약속입니다. 일반적으로 오류나 거부 이유를 나타내는 매개변수를 허용합니다. 예를 들면 다음과 같습니다.

<code class="javascript">return asyncIsPermitted()
    .then(function(result) {
        if (result === true) {
            return true;
        }
        else {
            return Promise.reject(new PermissionDenied());
        }
    });</code>
로그인 후 복사

Promise.reject를 사용하면 오류 처리를 더 효과적으로 제어할 수 있습니다. 거부된 값을 사용자 정의하여 추가 컨텍스트를 제공하거나 실패에 대한 특정 정보를 전달할 수 있기 때문입니다.

오류 발생

Promise 콜백 내에서 오류가 발생하면 후속 .catch() 핸들러가 트리거됩니다. 던져진 오류 객체는 약속의 거부된 값이 됩니다. Promise.reject()에 비해 더 간결한 구문입니다. 다음 예를 고려하십시오.

<code class="javascript">return asyncIsPermitted()
    .then(function(result) {
        if (result === true) {
            return true;
        }
        else {
            throw new PermissionDenied();
        }
    });</code>
로그인 후 복사

각 접근 방식을 사용하는 경우

Promise.reject와 오류 발생 모두 동일한 결과를 얻지만, 다음과 같은 특정 사례가 있습니다. 오류가 발생해도 .catch() 핸들러가 트리거되지 않습니다. Promise 콜백 외부, 비동기 콜백(예: setTimeout() 또는 비동기 함수의 콜백) 내부에서 오류가 발생하면 .catch()에 의해 포착되지 않습니다. 이러한 경우에는 Promise.reject()를 사용해야 합니다.

결론

일반적으로 Promise.reject와 Promise 내에서 오류 발생을 모두 사용할 수 있습니다. 약속을 거부하고 실패를 알립니다. Promise.reject는 거부된 값을 사용자 정의하는 데 더 많은 유연성을 제공하는 반면 오류 발생은 더 간결합니다. 모든 시나리오에서 올바른 오류 처리를 보장하려면 위에 언급된 예외를 기록하는 것이 중요합니다.

위 내용은 Promise.reject를 사용해야 하는 경우와 JavaScript Promise에서 오류를 발생시키는 경우는 언제인가요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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