這篇文章給大家分享的是有關JavaScript中使用async和await執(zhí)行異步處理的方法的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考。一起跟隨小編過來看看吧。
創(chuàng)新互聯(lián)是專業(yè)的覃塘網(wǎng)站建設公司,覃塘接單;提供成都網(wǎng)站建設、網(wǎng)站建設,網(wǎng)頁設計,網(wǎng)站設計,建網(wǎng)站,PHP網(wǎng)站建設等專業(yè)做網(wǎng)站服務;采用PHP框架,可快速的進行覃塘網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!Async/await是一個主要功能,可以更簡潔有效地描述Promise的異步處理,異步處理是無需等待處理結果就能馬上執(zhí)行下一個處理的機制,它可以很容易地通過使用Promise來實現(xiàn)。
在Promise的情況下,我們使用“then”來連接,因此它會變成很單調(diào)的代碼。
例如,如果使用“then”運行多個Promise進程,它看起來像這樣:
getDate() .then(function(data) { return getYear(data) }) .then(function(year) { return getSomething(year) }) .then(function(item) { getAnotherThing(item) })
在某些情況下,使用Promise.all()可以更好的實現(xiàn),但仍然必須使用then。
我們?nèi)绻麑W習了如何使用async/await,這樣就可以提高效率了。
如何使用async/await?
我們先來看一下基本的語法
async可以定義一個函數(shù),只需在function之前寫入就可以執(zhí)行異步處理。
async function() { }
如果這樣寫async,這個函數(shù)將返回Promise。
此外,await是Promise處理的結果返回之前暫時停止的運算符。
await Promise處理
通過在描述Promise處理的函數(shù)之前簡單地寫await,它會暫停直到結果返回。
但是,請注意await只能用于async中定義的函數(shù)!
同樣由于這個原因,async / await經(jīng)常會成對的使用。
如何使用async/await編寫異步處理?
首先,假設有以下Promise處理。
function myPromise(num) { return new Promise(function(resolve) { setTimeout(function() { resolve(num * num) }, 3000) }) }
這個例子,明白在Promise內(nèi)記述著故意花費3秒的時間的處理。
如果使用async/await而不使用then ,則如下所示。
async function myAsync() { var result = await myPromise(10); console.log(result); }
執(zhí)行結果為:100
在這個例子中,通過賦予async來創(chuàng)建異步處理的函數(shù)。
描述函數(shù)內(nèi)的Promise處理是myPromise()前的await
這將暫時等待Promise進程,該進程將在3秒后返回結果,并且一旦獲得結果,函數(shù)內(nèi)的進程將繼續(xù)處理。
在執(zhí)行結果中,可以獲得給定參數(shù)10相乘的值100。
感謝各位的閱讀!關于JavaScript中使用async和await執(zhí)行異步處理的方法就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
網(wǎng)頁題目:JavaScript中使用async和await執(zhí)行異步處理的方法-創(chuàng)新互聯(lián)
鏈接分享:http://aaarwkj.com/article22/cdpjjc.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站、域名注冊、做網(wǎng)站、外貿(mào)建站、網(wǎng)站改版、微信公眾號
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)