亚洲中字慕日产2020,大陆极品少妇内射AAAAAA,无码av大香线蕉伊人久久,久久精品国产亚洲av麻豆网站

資訊專欄INFORMATION COLUMN

JavaScript基礎(chǔ)——深入學(xué)習(xí)async/await

張金寶 / 485人閱讀

摘要:等待的基本語法該關(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,不信你可以使用Promisethen方法試試:

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中運行。

等待——await

await的基本語法:

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

相關(guān)文章

  • ES6-7

    摘要:的翻譯文檔由的維護(hù)很多人說,阮老師已經(jīng)有一本關(guān)于的書了入門,覺得看看這本書就足夠了。前端的異步解決方案之和異步編程模式在前端開發(fā)過程中,顯得越來越重要。為了讓編程更美好,我們就需要引入來降低異步編程的復(fù)雜性。 JavaScript Promise 迷你書(中文版) 超詳細(xì)介紹promise的gitbook,看完再不會promise...... 本書的目的是以目前還在制定中的ECMASc...

    mudiyouyou 評論0 收藏0
  • ES2017異步函數(shù)現(xiàn)已正式可用

    摘要:標(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ù)或多或...

    android_c 評論0 收藏0
  • JavaScript 異步

    摘要:從最開始的到封裝后的都在試圖解決異步編程過程中的問題。為了讓編程更美好,我們就需要引入來降低異步編程的復(fù)雜性。寫一個符合規(guī)范并可配合使用的寫一個符合規(guī)范并可配合使用的理解的工作原理采用回調(diào)函數(shù)來處理異步編程。 JavaScript怎么使用循環(huán)代替(異步)遞歸 問題描述 在開發(fā)過程中,遇到一個需求:在系統(tǒng)初始化時通過http獲取一個第三方服務(wù)器端的列表,第三方服務(wù)器提供了一個接口,可通過...

    tuniutech 評論0 收藏0
  • 【全文】狼叔:如何正確的學(xué)習(xí)Node.js

    摘要:感謝大神的免費的計算機(jī)編程類中文書籍收錄并推薦地址,以后在倉庫里更新地址,聲音版全文狼叔如何正確的學(xué)習(xí)簡介現(xiàn)在,越來越多的科技公司和開發(fā)者開始使用開發(fā)各種應(yīng)用。 說明 2017-12-14 我發(fā)了一篇文章《沒用過Node.js,就別瞎逼逼》是因為有人在知乎上黑Node.js。那篇文章的反響還是相當(dāng)不錯的,甚至連著名的hax賀老都很認(rèn)同,下班時讀那篇文章,竟然坐車的還坐過站了。大家可以很...

    Edison 評論0 收藏0
  • 【全文】狼叔:如何正確的學(xué)習(xí)Node.js

    摘要:感謝大神的免費的計算機(jī)編程類中文書籍收錄并推薦地址,以后在倉庫里更新地址,聲音版全文狼叔如何正確的學(xué)習(xí)簡介現(xiàn)在,越來越多的科技公司和開發(fā)者開始使用開發(fā)各種應(yīng)用。 說明 2017-12-14 我發(fā)了一篇文章《沒用過Node.js,就別瞎逼逼》是因為有人在知乎上黑Node.js。那篇文章的反響還是相當(dāng)不錯的,甚至連著名的hax賀老都很認(rèn)同,下班時讀那篇文章,竟然坐車的還坐過站了。大家可以很...

    fengxiuping 評論0 收藏0

發(fā)表評論

0條評論

張金寶

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<