成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Promise 和 Async/Await的區別

開發 前端
在 JavaScript 中,Promises? 和 Async/await 是處理異步操作的兩種不同方法。但它們之間關系密切。

如果你正在閱讀這篇文章,你可能已經理解了 promise 和 async/await 在執行上下文中的不同之處。

圖片

在 JavaScript 中,promises 和 async/await 是處理異步操作的兩種不同方法。但它們之間關系密切。

Promise

Promise 是最終導致異步操作完成或失敗的對象。Promise 可以處于三種狀態之一:待定、已完成或已拒絕。當異步操作完成時,Promise 要么以一個值實現,要么以一個錯誤被拒絕。

// Using Promises
function promiseFunction() {
  return  new Promise((resolve, reject) => {
  setTimeout(() => {
    resolve("Resolved");
  }, 2000);
})
}

console.log("Start");
promiseFunction()
.then((result) => {
  console.log(result);
  console.log("End");
})
.catch((error)=>{
console.log(error)
});

Output:
Start
Resolved
End

Async/Await

async/await 是 Promise 之上的語法糖。它為編寫異步代碼提供了一種更簡潔的方法,使其更易于閱讀和編寫。使用 async/await,可以編寫看起來與同步代碼相似的異步代碼,而且它在引擎蓋下使用了 Promise。

在 async/await 中, async 關鍵字用于聲明異步函數。 await 關鍵字用于在繼續執行函數之前等待承諾的解析。 await 關鍵字只能在 async 函數中使用。

// Using Async/Await
async function asyncFunction() {
  try {
    console.log("Start");
    const promise = new Promise((resolve, reject) => {
      setTimeout(() => {
        resolve("Resolved");
      }, 2000);
    });
    const result = await promise;
    console.log(result);
    console.log("End");
  } catch (error) {
    console.error(error);
  }
}

asyncFunction()

output:
Start
Resolved
End

差異

唯一的區別在于 promise 和 async/await 的執行上下文。

當創建 Promise 并啟動異步操作時,創建 Promise 后的代碼會繼續同步執行。當 Promise 被解析或拒絕時,附加的回調函數會被添加到微任務隊列中。微任務隊列會在當前任務完成后,但在下一個任務從任務隊列中處理出來之前進行處理。這意味著在創建 Promise 之后的任何代碼都將在執行附加到 Promise 的回調函數之前執行。

另一方面,在使用 async/await 時, await 關鍵字會使 JavaScript 引擎暫停執行 async 函數,直到 Promise 解析或被拒絕。當 async 函數等待 Promise 解析時,它不會阻塞調用棧,因此可以執行任何其他同步代碼。一旦 Promise 解析完畢, async 函數將繼續執行,并返回 Promise 的結果。如果被拒絕,則會拋出一個錯誤值。

責任編輯:姜華 來源: 大遷世界
相關推薦

2017-04-10 15:57:10

AsyncAwaitPromise

2021-06-07 09:44:10

JavaScript開發代碼

2024-09-02 14:12:56

2021-05-18 07:52:31

PromiseAsyncAwait

2017-06-19 09:12:08

JavaScriptPromiseAsync

2014-07-15 10:31:07

asyncawait

2016-11-22 11:08:34

asyncjavascript

2023-03-29 10:19:44

異步編程AsyncPromise

2014-07-15 10:08:42

異步編程In .NET

2022-06-24 08:33:13

ECMAScriptjavaScript

2012-07-22 15:59:42

Silverlight

2021-07-20 10:26:12

JavaScriptasyncawait

2022-08-27 13:49:36

ES7promiseresolve

2023-07-28 07:31:52

JavaScriptasyncawait

2021-06-28 07:27:43

AwaitAsync語法

2024-12-30 08:22:35

2020-10-23 10:10:59

Promise前端代碼

2022-11-21 09:01:00

Swift并發結構

2017-08-02 14:17:08

前端asyncawait

2024-06-25 08:33:48

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品美女久久久久 | 欧美日韩一区二区三区四区 | 亚洲一区二区久久 | wwwsihu| 国产日韩欧美一区 | 国产精品日日夜夜 | 亚洲三区在线观看 | 免费精品视频一区 | 自拍偷拍一区二区三区 | 欧洲一区在线观看 | 欧美成人影院 | 91精品国产91久久久久久最新 | 一区二区视屏 | 国产精品2 | 伊人网综合在线 | 欧美日日 | 成人在线黄色 | 欧美成人hd | 91视频大全 | 九九久久国产精品 | 国产不卡一区在线观看 | av片在线观看 | 日韩中文在线 | 精品国产一区二区三区性色av | av免费入口| 欧美一区视频 | 国产成人免费视频网站高清观看视频 | 国精日本亚洲欧州国产中文久久 | 成人在线一区二区三区 | 久久综合一区 | gav成人免费播放视频 | 中国大陆高清aⅴ毛片 | 91在线一区 | 久久精品视频网站 | 国产精品久久久久久一区二区三区 | 日韩午夜影院 | 中文字幕亚洲视频 | 男女精品网站 | 精品免费国产视频 | 日韩精品无码一区二区三区 | 高清国产午夜精品久久久久久 |