> 웹 프론트엔드 > JS 튜토리얼 > 비동기 JavaScript 함수는 항상 Promise를 반환합니까?

비동기 JavaScript 함수는 항상 Promise를 반환합니까?

Patricia Arquette
풀어 주다: 2024-12-23 16:20:12
원래의
312명이 탐색했습니다.

Do Async JavaScript Functions Always Return Promises?

비동기 함수 및 암시적 Promise 반환

JavaScript에서 async 키워드로 표시된 비동기 함수는 암시적으로 Promise를 반환합니다. 이는 Promise가 아닌 값을 명시적으로 반환하거나 아무것도 반환하지 않는 경우에도 마찬가지입니다.

암시적 Promise Wrapper

promise를 사용하면 반환되는 값이 자동으로 promise로 래핑됩니다.

async function increment(num) {
  return num + 1;
}

// Logs: 4
increment(3).then(num => console.log(num));
로그인 후 복사

즉, 반환 값이 번호가 있는 경우 비동기 처리를 위해 Promise로 변환됩니다.

Unwrapped Promise

자동 언래핑을 약속합니다. 즉, 다음에 대한 Promise를 반환하는 경우를 의미합니다. 비동기 함수 내에서 값을 가져오면 해당 값에 대한 약속을 받게 됩니다. 값).

async function increment(num) {
  return defer(() => num + 1);
}

// Logs: 4
increment(3).then(num => console.log(num));
로그인 후 복사

일관되지 않은 동작

비동기 함수의 동작은 약속되지 않은 값을 명시적으로 반환할 때 다르기 때문에 실제로 전통적인 반환 문과 일치하지 않는 것처럼 보일 수 있습니다. . 이는 비동기 함수가 항상 return 문과 동일한 값을 반환하지 않는 생성기라는 특수한 유형의 함수를 활용하기 때문입니다.

위 내용은 비동기 JavaScript 함수는 항상 Promise를 반환합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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