ES7中async + await的用法

一竭恬、前序

異步操作是javascript編程的一件麻煩事,麻煩到一直有人提出各種各樣的解決方案蝌麸,試圖解決這個(gè)問(wèn)題。但是從最早的回調(diào)函數(shù)艾疟,到Promise對(duì)象来吩,再到Generator函數(shù),雖每次都有所改進(jìn)蔽莱,卻仍舊讓人感覺(jué)到復(fù)雜弟疆。而相比上述幾種方案,async函數(shù)無(wú)疑是讓我們眼前一亮的解決方案盗冷。

二怠苔、async函數(shù)是什么

一句話(huà)概括,async函數(shù)就是Generator函數(shù)的語(yǔ)法糖仪糖。


const fs = require('fs')

function readFile (fileName) {
  return new Promise((resolve, reject) => {
    fs.readFile(fileName, (error, data) => {
      if (error) {
        reject(error)
      } else {
        resolve(data)
      }
    })  
  })
}

/* Generator函數(shù)依次讀取兩個(gè)文件 */
function* gen () {
  const f1 = yield readFile('/etc/fstab')
  const f2 = yield readFile('/etc/shells')
  console.log(f1.toString())
  console.log(f2.toString())
}


/* async函數(shù)依次讀取兩個(gè)文件 */
async function asyncReadFile () {
  const f1 = await readFile('/etc/fstab')
  const f2 = await readFile('/etc/shells')
  console.log(f1.toString())
  console.log(f2.toString())
}


比較async函數(shù)和generator函數(shù)柑司,可以發(fā)現(xiàn)async函數(shù)就是將generator函數(shù)的星號(hào)(*)替換成了async, 將yield替換成了await, 僅此而已。

三锅劝、async函數(shù)的優(yōu)點(diǎn)

  • 內(nèi)置執(zhí)行器
    async函數(shù)的執(zhí)行攒驰,與普通函數(shù)一摸一樣,只需一行即可完成鸠天。
let result = asyncReadFile()

  • 語(yǔ)義更清楚讼育。

    • async: 表示函數(shù)內(nèi)存在異步操作
    • await:表示需要等待緊跟在后面的表達(dá)式返回結(jié)果
  • 實(shí)用性更廣

    • await:緊跟其后的帐姻,可以是Promise對(duì)象稠集,也可以是原始類(lèi)型的值(數(shù)值、字符串饥瓷、布爾值剥纷,但此時(shí)等同于同步操作)

四、async函數(shù)的實(shí)現(xiàn)(了解即可)

async函數(shù)的實(shí)現(xiàn)呢铆,就是將generator函數(shù)和自動(dòng)執(zhí)行器晦鞋,包裝在一個(gè)函數(shù)里。模板如下:

async function fn (args) {
  // ...
}

// 等同于 (其中spawn函數(shù)就是自動(dòng)執(zhí)行器)
function fn(args) {
  return spawn(function* () {
    // ...
  })
}

五棺克、async函數(shù)的用法(重點(diǎn))

同generator函數(shù)一樣悠垛,async函數(shù)返回一個(gè)Pormise對(duì)象,故而可以使用then方法添加回調(diào)函數(shù)娜谊。當(dāng)async函數(shù)執(zhí)行時(shí)确买,一旦遇到await就會(huì)先返回等到觸發(fā)的異步操作完成,才會(huì)接著執(zhí)行函數(shù)體后面的語(yǔ)句纱皆。

/* 示例一: 獲取股票報(bào)價(jià) */
async function getStockPriceByName(name) {
  var symbol = await getStockSymbol(name);
  var stockPrice = await getStockPrice(symbol);
  return stockPrice;
}

getStockPriceByName('goog').then(function (result){
  console.log(result);
});


上面的示例湾趾,函數(shù)前面的async關(guān)鍵字芭商,表明該函數(shù)內(nèi)有異步操作。調(diào)用該函數(shù)時(shí)會(huì)立即返回一個(gè)Promise對(duì)象搀缠。

/* 示例二: 指定n毫秒后輸出一個(gè)值 */
function timeout(ms) {
  return new Promise((resolve) => {
    setTimeout(resolve, ms);
  });
}

async function asyncPrint(value, ms) {
  await timeout(ms);
  console.log(value)
}

asyncPrint('hello world', 50);

上面的示例铛楣,在50毫秒后,會(huì)輸出“hello world”

六艺普、注意點(diǎn)

  • await命令后面的Promise對(duì)象簸州,運(yùn)行結(jié)果可能時(shí)rejected,故而建議:最好將await命令放在try...catch代碼塊中

  • await命令只能用在async函數(shù)內(nèi)歧譬,若用在普通函數(shù)中就會(huì)報(bào)錯(cuò)

七勿侯、參考文檔

  1. async 函數(shù)的含義和用法
  2. Generator 函數(shù)的含義與用法
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市缴罗,隨后出現(xiàn)的幾起案子助琐,更是在濱河造成了極大的恐慌,老刑警劉巖面氓,帶你破解...
    沈念sama閱讀 206,126評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件兵钮,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡舌界,警方通過(guò)查閱死者的電腦和手機(jī)掘譬,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)呻拌,“玉大人葱轩,你說(shuō)我怎么就攤上這事∶晡眨” “怎么了靴拱?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,445評(píng)論 0 341
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)猾普。 經(jīng)常有香客問(wèn)我袜炕,道長(zhǎng),這世上最難降的妖魔是什么初家? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,185評(píng)論 1 278
  • 正文 為了忘掉前任偎窘,我火速辦了婚禮,結(jié)果婚禮上溜在,老公的妹妹穿的比我還像新娘陌知。我一直安慰自己,他們只是感情好掖肋,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,178評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布仆葡。 她就那樣靜靜地躺著,像睡著了一般培遵。 火紅的嫁衣襯著肌膚如雪浙芙。 梳的紋絲不亂的頭發(fā)上登刺,一...
    開(kāi)封第一講書(shū)人閱讀 48,970評(píng)論 1 284
  • 那天,我揣著相機(jī)與錄音嗡呼,去河邊找鬼纸俭。 笑死,一個(gè)胖子當(dāng)著我的面吹牛南窗,可吹牛的內(nèi)容都是我干的揍很。 我是一名探鬼主播,決...
    沈念sama閱讀 38,276評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼万伤,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼窒悔!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起敌买,我...
    開(kāi)封第一講書(shū)人閱讀 36,927評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤简珠,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后虹钮,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體聋庵,經(jīng)...
    沈念sama閱讀 43,400評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,883評(píng)論 2 323
  • 正文 我和宋清朗相戀三年芙粱,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了祭玉。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 37,997評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡春畔,死狀恐怖脱货,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情律姨,我是刑警寧澤振峻,帶...
    沈念sama閱讀 33,646評(píng)論 4 322
  • 正文 年R本政府宣布,位于F島的核電站线召,受9級(jí)特大地震影響铺韧,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜缓淹,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,213評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望塔逃。 院中可真熱鬧讯壶,春花似錦、人聲如沸湾盗。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,204評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)格粪。三九已至躏吊,卻和暖如春氛改,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背比伏。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,423評(píng)論 1 260
  • 我被黑心中介騙來(lái)泰國(guó)打工胜卤, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人赁项。 一個(gè)月前我還...
    沈念sama閱讀 45,423評(píng)論 2 352
  • 正文 我出身青樓葛躏,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親悠菜。 傳聞我的和親對(duì)象是個(gè)殘疾皇子舰攒,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,722評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容

  • 當(dāng)我還在使用promise來(lái)發(fā)送異步請(qǐng)求的時(shí)候,部門(mén)前端大佬已經(jīng)改用async/ await了悔醋,代碼很簡(jiǎn)潔摩窃,同時(shí)a...
    dingFY閱讀 308評(píng)論 0 1
  • 1、async await 的出現(xiàn)原因: JavaScript中最蛋疼的事情莫過(guò)于回調(diào)函數(shù)嵌套問(wèn)題芬骄。以往在瀏覽器中...
    葛高召閱讀 1,448評(píng)論 2 2
  • 在最開(kāi)始學(xué)習(xí)ES6的Promise時(shí)偶芍,曾寫(xiě)過(guò)一篇博文《promise和co搭配生成器函數(shù)方式解決js代碼異步流程的...
    coolcao閱讀 953評(píng)論 0 3
  • async await:用同步的方式來(lái)寫(xiě)異步async函數(shù)返回一個(gè) Promise 對(duì)象,可以使用then方法添加...
    蘇打丶觀閱讀 3,014評(píng)論 1 1
  • 1德玫、什么是async匪蟀、await? async顧名思義是“異步”的意思宰僧,async用于聲明一個(gè)函數(shù)是異步的材彪。而aw...
    _littleTank_閱讀 899評(píng)論 0 1