비동기 함수: 암시적 약속 반환 또는 명시적 제어?
async 키워드로 표시되는 JavaScript의 비동기 함수는 암시적으로 언급되는 경우가 많습니다. 약속을 반환합니다. 그러나 자세히 살펴보면 현실은 더 미묘한 차이가 있음을 알 수 있습니다.
기본적으로 비동기 함수는 약속이 명시적으로 반환되지 않으면 실제로 약속을 반환합니다. 이는 다음 코드가 다음 코드와 동일함을 의미합니다.
async function getVal() { const result = await doSomethingAsync(); return result; }
async function getVal() { const result = await doSomethingAsync(); return Promise.resolve(result); }
그러나 Promise가 아닌 값을 명시적으로 반환하는 경우 함수는 이를 자동으로 Promise로 래핑합니다. . 예를 들어, 다음 예에서는
async function getVal() { return doSomethingNonAsync(); }
getVal이 실제로 doSomethingNonAsync()의 결과가 포함된 Promise 객체를 반환합니다.
이 동작이 기존 JavaScript 함수와 다르다는 점은 주목할 가치가 있습니다. 일반 함수에서 기본 값을 명시적으로 반환하면 즉시 반환됩니다. 그러나 비동기 함수는 항상 Promise를 반환하고 필요에 따라 Promise가 아닌 값을 래핑합니다.
이는 일관성이 없어 보일 수 있지만 ES6의 생성기 개념과 맞물립니다. 생성기는 return 문과 동일한 값을 반환하지 않는 함수입니다. 대신, 산출 연산자를 사용하여 반복할 수 있는 일련의 값을 산출합니다.
예:
function* getVal() { yield doSomethingAsync(); return 'finished'; } // Logs an object. console.log(getVal()); // Logs 'yikes' and then 'finished'. for (const val of getVal()) { console.log(val); }
위 내용은 JavaScript의 비동기 함수: 암시적 약속 또는 명시적 반환 값?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!