摘要:等待的基本語法該關(guān)鍵字的的意思就是讓編譯器等待并返回結(jié)果。這里并不會占用資源,因為引擎可以同時執(zhí)行其他任務(wù)其他腳本或處理事件。接下來,我們寫一個火箭發(fā)射場景的小例子不是真的發(fā)射火箭
本文由云+社區(qū)發(fā)表
本篇文章,小編將和大家一起學(xué)習(xí)異步編程的未來——async/await,它會打破你對上篇文章Promise的認(rèn)知,竟然異步代碼還能這么寫! 但是別太得意,你需要深入理解Promise后,才能更好的的駕馭async/await,因為async/await是基于Promise的。
關(guān)于async / await用于編寫異步程序
代碼書寫方式和同步編碼十分相似,因此代碼十分簡潔易讀
基于Promise
您可以使用try-catch常規(guī)的方法捕獲異常
ES8中引入了async/await,目前幾乎所有的現(xiàn)代瀏覽器都已支持這個特性(除了IE和Opera不支持)
你可以輕松設(shè)置斷點,調(diào)試更容易。
從async開始學(xué)起讓我們從async關(guān)鍵字開始吧,這個關(guān)鍵字可以放在函數(shù)之前,如下所示:
async function f() { return 1; }
在函數(shù)之間加上async意味著:函數(shù)將返回一個Promise,雖然你的代碼里沒有顯示的聲明返回一個Promise,但是編譯器會自動將其轉(zhuǎn)換成一個Promise,不信你可以使用Promise的then方法試試:
async function f() { return 1; } f().then(alert); // 1
...如果你不放心的話,你可以在代碼里明確返回一個Promise,輸出結(jié)果是相同的。
async function f() { return Promise.resolve(1); } f().then(alert); // 1
很簡單吧,小編之所以說 async/await 是基于Promise是沒毛病的,async函數(shù)返回一個Promise,很簡單吧,不僅如此,還有一個關(guān)鍵字await,await只能在async中運行。
等待——awaitawait的基本語法:
let value=await promise;
該關(guān)鍵字的await的意思就是讓JS編譯器等待Promise并返回結(jié)果。接下來我們看一段簡單的示例:
async function f() { let promise = new Promise((resolve, reject) => { setTimeout(() => resolve("done!"), 1000) }); let result = await promise; // wait till the promise resolves (*) alert(result); // "done!" } f();
函數(shù)執(zhí)行將會在 let result = await promise 這一行暫停,直到Promise返回結(jié)果,因此上述代碼將會1秒后,在瀏覽器彈出“done”的提示框。
小編在此強(qiáng)調(diào)下:
await的字面意思就是讓JavaScript等到Promise結(jié)束,然后輸出結(jié)果。這里并不會占用CPU資源,因為引擎可以同時執(zhí)行其他任務(wù):其他腳本或處理事件。
不能多帶帶使用await,必須在async函數(shù)作用域下使用,否則將會報出異?!癊rror: await is only valid in async function”,示例代碼如下:
function f() { let promise = Promise.resolve(1); let result = await promise; // Syntax error }接下來,小編將和大家一起來親自動手實踐以下內(nèi)容:
async與Promise.then的結(jié)合,依次處理多個結(jié)果
使用await替代Promise.then,依次處理多個結(jié)果
同時等待多個結(jié)果
使用Promise.all收集多個結(jié)果
使用try-catch捕獲異常
如何捕獲Promise.all中的異常
使用finally確保函數(shù)執(zhí)行
一起動手之前,確保你安裝了Node,NPM相關(guān)工具,谷歌瀏覽器,為了預(yù)覽代碼效果,小編使用 npm install http-server -g 命令快速部署了web服務(wù)環(huán)境,方便我們運行代碼。接下來,我們寫一個火箭發(fā)射場景的小例子(不是真的發(fā)射火箭
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://www.ezyhdfw.cn/yun/72807.html
摘要:的翻譯文檔由的維護(hù)很多人說,阮老師已經(jīng)有一本關(guān)于的書了入門,覺得看看這本書就足夠了。前端的異步解決方案之和異步編程模式在前端開發(fā)過程中,顯得越來越重要。為了讓編程更美好,我們就需要引入來降低異步編程的復(fù)雜性。 JavaScript Promise 迷你書(中文版) 超詳細(xì)介紹promise的gitbook,看完再不會promise...... 本書的目的是以目前還在制定中的ECMASc...
摘要:標(biāo)準(zhǔn)已于年月份正式定稿了,并廣泛支持最新的特性異步函數(shù)。為了領(lǐng)會,我們需要回到普通回調(diào)函數(shù)中進(jìn)一步學(xué)習(xí)。從此編寫回調(diào)函數(shù)不再那么痛苦?;卣{(diào)是一個函數(shù),可以將結(jié)果傳遞給函數(shù)并在該函數(shù)內(nèi)進(jìn)行調(diào)用,以便作為事件的響應(yīng)。 ES2017標(biāo)準(zhǔn)已于2017年6月份正式定稿了,并廣泛支持最新的特性:異步函數(shù)。如果你曾經(jīng)被異步 JavaScript 的邏輯困擾,這么新函數(shù)正是為你設(shè)計的。 異步函數(shù)或多或...
摘要:從最開始的到封裝后的都在試圖解決異步編程過程中的問題。為了讓編程更美好,我們就需要引入來降低異步編程的復(fù)雜性。寫一個符合規(guī)范并可配合使用的寫一個符合規(guī)范并可配合使用的理解的工作原理采用回調(diào)函數(shù)來處理異步編程。 JavaScript怎么使用循環(huán)代替(異步)遞歸 問題描述 在開發(fā)過程中,遇到一個需求:在系統(tǒng)初始化時通過http獲取一個第三方服務(wù)器端的列表,第三方服務(wù)器提供了一個接口,可通過...
摘要:感謝大神的免費的計算機(jī)編程類中文書籍收錄并推薦地址,以后在倉庫里更新地址,聲音版全文狼叔如何正確的學(xué)習(xí)簡介現(xiàn)在,越來越多的科技公司和開發(fā)者開始使用開發(fā)各種應(yīng)用。 說明 2017-12-14 我發(fā)了一篇文章《沒用過Node.js,就別瞎逼逼》是因為有人在知乎上黑Node.js。那篇文章的反響還是相當(dāng)不錯的,甚至連著名的hax賀老都很認(rèn)同,下班時讀那篇文章,竟然坐車的還坐過站了。大家可以很...
摘要:感謝大神的免費的計算機(jī)編程類中文書籍收錄并推薦地址,以后在倉庫里更新地址,聲音版全文狼叔如何正確的學(xué)習(xí)簡介現(xiàn)在,越來越多的科技公司和開發(fā)者開始使用開發(fā)各種應(yīng)用。 說明 2017-12-14 我發(fā)了一篇文章《沒用過Node.js,就別瞎逼逼》是因為有人在知乎上黑Node.js。那篇文章的反響還是相當(dāng)不錯的,甚至連著名的hax賀老都很認(rèn)同,下班時讀那篇文章,竟然坐車的還坐過站了。大家可以很...
閱讀 2130·2019-08-30 15:52
閱讀 2505·2019-08-29 18:37
閱讀 862·2019-08-29 12:33
閱讀 2907·2019-08-29 11:04
閱讀 1632·2019-08-27 10:57
閱讀 2159·2019-08-26 13:38
閱讀 2831·2019-08-26 12:25
閱讀 2519·2019-08-26 12:23