這篇文章給大家分享的是有關(guān)JavaScript中使用async和await執(zhí)行異步處理的方法的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧。
創(chuàng)新互聯(lián)是一家專(zhuān)業(yè)提供疊彩企業(yè)網(wǎng)站建設(shè),專(zhuān)注與成都網(wǎng)站設(shè)計(jì)、網(wǎng)站制作、外貿(mào)營(yíng)銷(xiāo)網(wǎng)站建設(shè)、H5建站、小程序制作等業(yè)務(wù)。10年已為疊彩眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專(zhuān)業(yè)網(wǎng)站建設(shè)公司優(yōu)惠進(jìn)行中。
Async/await是一個(gè)主要功能,可以更簡(jiǎn)潔有效地描述Promise的異步處理,異步處理是無(wú)需等待處理結(jié)果就能馬上執(zhí)行下一個(gè)處理的機(jī)制,它可以很容易地通過(guò)使用Promise來(lái)實(shí)現(xiàn)。
在Promise的情況下,我們使用“then”來(lái)連接,因此它會(huì)變成很單調(diào)的代碼。
例如,如果使用“then”運(yùn)行多個(gè)Promise進(jìn)程,它看起來(lái)像這樣:
getDate() .then(function(data) { return getYear(data) }) .then(function(year) { return getSomething(year) }) .then(function(item) { getAnotherThing(item) })
在某些情況下,使用Promise.all()可以更好的實(shí)現(xiàn),但仍然必須使用then。
我們?nèi)绻麑W(xué)習(xí)了如何使用async/await,這樣就可以提高效率了。
如何使用async/await?
我們先來(lái)看一下基本的語(yǔ)法
async可以定義一個(gè)函數(shù),只需在function之前寫(xiě)入就可以執(zhí)行異步處理。
async function() { }
如果這樣寫(xiě)async,這個(gè)函數(shù)將返回Promise。
此外,await是Promise處理的結(jié)果返回之前暫時(shí)停止的運(yùn)算符。
await Promise處理
通過(guò)在描述Promise處理的函數(shù)之前簡(jiǎn)單地寫(xiě)await,它會(huì)暫停直到結(jié)果返回。
但是,請(qǐng)注意await只能用于async中定義的函數(shù)!
同樣由于這個(gè)原因,async / await經(jīng)常會(huì)成對(duì)的使用。
如何使用async/await編寫(xiě)異步處理?
首先,假設(shè)有以下Promise處理。
function myPromise(num) { return new Promise(function(resolve) { setTimeout(function() { resolve(num * num) }, 3000) }) }
這個(gè)例子,明白在Promise內(nèi)記述著故意花費(fèi)3秒的時(shí)間的處理。
如果使用async/await而不使用then ,則如下所示。
async function myAsync() { var result = await myPromise(10); console.log(result); }
執(zhí)行結(jié)果為:100
在這個(gè)例子中,通過(guò)賦予async來(lái)創(chuàng)建異步處理的函數(shù)。
描述函數(shù)內(nèi)的Promise處理是myPromise()前的await
這將暫時(shí)等待Promise進(jìn)程,該進(jìn)程將在3秒后返回結(jié)果,并且一旦獲得結(jié)果,函數(shù)內(nèi)的進(jìn)程將繼續(xù)處理。
在執(zhí)行結(jié)果中,可以獲得給定參數(shù)10相乘的值100。
感謝各位的閱讀!關(guān)于JavaScript中使用async和await執(zhí)行異步處理的方法就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
新聞名稱(chēng):JavaScript中使用async和await執(zhí)行異步處理的方法
當(dāng)前地址:http://www.rwnh.cn/article2/pgseoc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄、做網(wǎng)站、網(wǎng)站排名、商城網(wǎng)站、響應(yīng)式網(wǎng)站、外貿(mào)網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)