JS中async/await實(shí)現(xiàn)異步調(diào)用的方法
async/await多個(gè)函數(shù)關(guān)聯(lián)調(diào)用
async/await使得異步代碼看起來(lái)像同步代碼
async函數(shù)會(huì)隱式地返回一個(gè)promise,而promise的reosolve值就是函數(shù)return的值
Async/Await不需要寫.then,不需要寫匿名函數(shù)處理Promise的resolve值,也不需要定義多余的data變量,還避免了嵌套代碼
async聲明一個(gè)異步函數(shù)
await只能在async函數(shù)中使用,后面跟一個(gè)promise對(duì)象
所以在模擬異步調(diào)用函數(shù)時(shí),函數(shù)體內(nèi)返回promise
async/await缺點(diǎn)
async函數(shù)里,無(wú)論是Promise reject的數(shù)據(jù)還是邏輯報(bào)錯(cuò),都會(huì)被默默吞掉。所以最好把a(bǔ)wait放入try{}catch{}中,或者在async返回的promise對(duì)象中使用.cache捕獲錯(cuò)誤。
實(shí)現(xiàn)
項(xiàng)目中實(shí)現(xiàn)三個(gè)不同的接口調(diào)用,三個(gè)接口是相互關(guān)聯(lián)的,前一個(gè)接口的返回值是后一個(gè)接口的參數(shù),如果使用Promise實(shí)現(xiàn)的話,只能實(shí)現(xiàn)異步調(diào)用,但是無(wú)法相互關(guān)聯(lián),也就是數(shù)據(jù)不互通,所以使用async/await實(shí)現(xiàn)
- 接口調(diào)用的方法獨(dú)立封裝,參數(shù)可動(dòng)態(tài)設(shè)置
- async聲明異步方法,內(nèi)部使用await關(guān)鍵字調(diào)用封裝的接口,參數(shù)可直接傳入
- async/await相當(dāng)于將Promise異步調(diào)用同步化,數(shù)據(jù)可實(shí)現(xiàn)關(guān)聯(lián)
- async/await會(huì)默認(rèn)返回一個(gè)Promise對(duì)象,在實(shí)際調(diào)用中使用cache捕獲錯(cuò)誤
代碼實(shí)現(xiàn)
<script> //再此使用定時(shí)器模擬異步接口的調(diào)用 // 異步函數(shù)a function a() { return new Promise(resolve => { setTimeout(()=>{ resolve('a') }, 1000) }) } // 異步函數(shù)b,關(guān)聯(lián)a參數(shù) function b(a) { return new Promise(resolve => { setTimeout(()=>{ resolve(a+'b') }, 1000) }) } // 異步函數(shù)c,關(guān)聯(lián)b參數(shù) function c(b) { return new Promise(resolve => { setTimeout(()=>{ resolve(b+'c') }, 1000) }) } // 同步執(zhí)行三個(gè)關(guān)聯(lián)的異步函數(shù) async function d(){ const da = await a(); const db = await b(da); const dc = await c(db); return dc; } // 實(shí)際調(diào)用 d().then(res=>{ console.log(res) }).catch(err=>{ console.log(err) }); </script>
總結(jié)
以上所述是小編給大家介紹的JS中async/await實(shí)現(xiàn)異步調(diào)用的方法,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
相關(guān)文章
javascript實(shí)現(xiàn)相同事件名稱,不同命名空間的調(diào)用方法
這篇文章主要介紹了javascript實(shí)現(xiàn)相同事件名稱,不同命名空間的調(diào)用方法,涉及javascript命名空間及事件調(diào)用的技巧,需要的朋友可以參考下2015-06-06js實(shí)現(xiàn)動(dòng)態(tài)改變字體大小代碼
本文為大家介紹下使用js如何實(shí)現(xiàn)動(dòng)態(tài)改變字體大小,感興趣的額朋友不要錯(cuò)過(guò)2014-01-0120分鐘輕松創(chuàng)建自己的Bootstrap站點(diǎn)
這篇文章主要教大家如何在短短的20分鐘內(nèi)輕松創(chuàng)建自己的Bootstrap站點(diǎn),學(xué)會(huì)使用twitter bootstrap建立一個(gè)站點(diǎn),從而鞏固Bootstrap一系列基礎(chǔ)知識(shí),感興趣的小伙伴們可以參考一下2016-05-05IE DOM實(shí)現(xiàn)存在的部分問(wèn)題及解決方法
IE DOM實(shí)現(xiàn)存在的部分問(wèn)題及解決方法2009-07-07zepto.js中tap事件阻止冒泡的實(shí)現(xiàn)方法
這篇文章主要介紹了zepto.js中tap事件阻止冒泡的實(shí)現(xiàn)方法,實(shí)例分析了由冒泡產(chǎn)生的click延遲解決方法,需要的朋友可以參考下2015-02-02JS實(shí)現(xiàn)的簡(jiǎn)潔二級(jí)導(dǎo)航菜單雛形效果
這篇文章主要介紹了JS實(shí)現(xiàn)的簡(jiǎn)潔二級(jí)導(dǎo)航菜單雛形效果,通過(guò)簡(jiǎn)單的JavaScript響應(yīng)鼠標(biāo)事件遍歷頁(yè)面元素實(shí)現(xiàn)二級(jí)導(dǎo)航菜單切換的效果,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下2015-10-10js實(shí)現(xiàn)一個(gè)簡(jiǎn)單的數(shù)字時(shí)鐘效果
本文主要介紹了js實(shí)現(xiàn)一個(gè)簡(jiǎn)單的數(shù)字時(shí)鐘效果的示例代碼。具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-03-03