>웹 프론트엔드 >JS 튜토리얼 >JavaScript의 async/await는 항상 Promise를 반환합니까? 그 이유는 무엇입니까?

JavaScript의 async/await는 항상 Promise를 반환합니까? 그 이유는 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-12-12 11:54:10867검색

Does async/await in JavaScript Always Return a Promise, and Why?

async/await: Promise Unveiled

Promise는 JavaScript 비동기 프로그래밍의 기본 측면입니다. 비동기/대기의 경우 비동기 함수가 항상 Promise를 반환한다는 개념을 이해하는 것이 중요합니다.

Promise 반환 함수 호출 앞에 배치된 wait 키워드는 다음이 발생할 때까지 현재 함수의 실행을 일시 중지합니다. 약속은 해결되거나 거부됩니다. 그러나 이번 정지로 인해 약속이 풀리지는 않습니다. Promise의 결과는 반환된 Promise 객체 내에 여전히 캡슐화되어 있습니다.

설명을 위해 비동기 요청을 시뮬레이션하는 다음 코드를 고려해 보세요.

const getJSON = async () => {
  const request = () => new Promise((resolve, reject) => (
    setTimeout(() => resolve({ foo: 'bar' }), 2000)
  ));

  const json = await request();
  return json;
};

getJSON()을 호출하면 반환되는 코드는 다음과 같습니다. wait 문은 요청이 완료될 때까지 실행을 일시 중단하기 때문에 약속합니다.

console.log(getJSON()); // returns Promise

In 대조적으로, .then()을 연결하면 Promise의 결과가 마침내 노출됩니다.

getJSON().then(json => console.log(json)); // prints { foo: 'bar' }

왜 console.log(getJSON())를 사용하여 Promise 래핑을 우회할 수 없나요? 이는 Promise의 기본 속성입니다. 약속은 비동기 작업을 나타내며 그 결과는 해결되거나 거부될 때까지 알 수 없습니다. 결과에 대한 외부 액세스는 의도적으로 금지되어 Promise가 결과의 유일한 중재자로 유지되도록 합니다.

async/await는 Promise가 발생할 때 실행을 일시 중지하여 Promise 작업을 더욱 편리하게 만들어 주지만 그렇지는 않습니다. 결과에 접근하기 위해 Promise를 풀 필요가 없습니다.

위 내용은 JavaScript의 async/await는 항상 Promise를 반환합니까? 그 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.