首頁 > web前端 > js教程 > 非同步函數總是回傳 Promise 嗎?

非同步函數總是回傳 Promise 嗎?

Mary-Kate Olsen
發布: 2024-12-25 02:09:12
原創
809 人瀏覽過

Do Async Functions Always Return Promises?

問題:非同步函數是否隱式回傳 Promise?

在 JavaScript 中,非同步函數是使用 async 關鍵字聲明的,並且通常被認為會自動傳回回報承諾。但是,這會引發潛在的不一致:當明確傳回非 Promise 值時,該函數似乎將該值包裝在 Promise 中。

答案:所有非同步函數都會回傳 Promises

觀察到的行為是正確的:所有非同步函數都隱含回傳 Promise。具體來說:

  • 當非同步函數在沒有明確傳回語句的情況下傳回時,它會傳回一個解析為未定義的 Promise。
  • 當非同步函數明確傳回非 Promise 值時,它會包裝Promise 中的值解析為該值。
  • 即使非同步函數包含等待表達式,傳回的值仍然是一個 Promise,包裝了以下結果wait 表達式。
  • 如果非同步函數內拋出錯誤,則傳回的 Promise 會因該錯誤而被拒絕。

範例:

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

// Logs 4, as the returned promise resolves to 4.
increment(3).then(num => console.log(num));
登入後複製

包裹行為:

這個包裝行為是生成器函數所獨用器有的。例如,生成器函數也會傳回 Promise,但方式不同:

function* foo() {
  return 'test';
}

// Logs an object, not "test".
console.log(foo());

// Logs 'test' by explicitly calling .next() on the generator function.
console.log(foo().next().value);
登入後複製

以上是非同步函數總是回傳 Promise 嗎?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板