91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在JavaScript中使用async和await實現異步調用

發布時間:2021-03-10 16:03:10 來源:億速云 閱讀:200 作者:Leah 欄目:web開發

今天就跟大家聊聊有關怎么在JavaScript中使用async和await實現異步調用,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

async/await多個函數關聯調用

async/await使得異步代碼看起來像同步代碼

async函數會隱式地返回一個promise,而promise的reosolve值就是函數return的值

Async/Await不需要寫.then,不需要寫匿名函數處理Promise的resolve值,也不需要定義多余的data變量,還避免了嵌套代碼

async聲明一個異步函數

await只能在async函數中使用,后面跟一個promise對象

所以在模擬異步調用函數時,函數體內返回promise

async/await缺點

async函數里,無論是Promise reject的數據還是邏輯報錯,都會被默默吞掉。所以最好把await放入try{}catch{}中,或者在async返回的promise對象中使用.cache捕獲錯誤。

實現

項目中實現三個不同的接口調用,三個接口是相互關聯的,前一個接口的返回值是后一個接口的參數,如果使用Promise實現的話,只能實現異步調用,但是無法相互關聯,也就是數據不互通,所以使用async/await實現

  • 接口調用的方法獨立封裝,參數可動態設置

  • async聲明異步方法,內部使用await關鍵字調用封裝的接口,參數可直接傳入

  • async/await相當于將Promise異步調用同步化,數據可實現關聯

  • async/await會默認返回一個Promise對象,在實際調用中使用cache捕獲錯誤

代碼實現

<script>
 //再此使用定時器模擬異步接口的調用
 // 異步函數a
 function a() {
  return new Promise(resolve => {
   setTimeout(()=>{
    resolve('a')
   }, 1000)
  })
 }
 // 異步函數b,關聯a參數
 function b(a) {
  return new Promise(resolve => {
   setTimeout(()=>{
    resolve(a+'b')
   }, 1000)
  })
 }
 // 異步函數c,關聯b參數
 function c(b) {
  return new Promise(resolve => {
   setTimeout(()=>{
    resolve(b+'c')
   }, 1000)
  })
 }

 // 同步執行三個關聯的異步函數
 async function d(){
   const da = await a();
   const db = await b(da);
   const dc = await c(db);
   return dc;
 }

 // 實際調用
 d().then(res=>{
  console.log(res)
 }).catch(err=>{
  console.log(err)
 });
</script>

看完上述內容,你們對怎么在JavaScript中使用async和await實現異步調用有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

绥中县| 澜沧| 丰原市| 双江| 仁化县| 建瓯市| 凌海市| 皮山县| 阳春市| 乡宁县| 始兴县| 庄浪县| 休宁县| 宜章县| 永清县| 临安市| 泰顺县| 衡阳县| 潮安县| 资阳市| 增城市| 宝兴县| 崇礼县| 万年县| 兰溪市| 木兰县| 新竹市| 巴青县| 鹤山市| 库伦旗| 同仁县| 神农架林区| 内丘县| 安多县| 郎溪县| 新巴尔虎左旗| 安国市| 会泽县| 康平县| 丹寨县| 桦川县|