async 函數(shù)與 Promise愉豺、Generator 函數(shù)的區(qū)別

假定某個(gè) DOM 元素上面,部署了一系列的動(dòng)畫茫因,前一個(gè)動(dòng)畫結(jié)束蚪拦,才能開始后一個(gè)。如果當(dāng)中有一個(gè)動(dòng)畫出錯(cuò),就不再往下執(zhí)行驰贷,返回上一個(gè)成功執(zhí)行的動(dòng)畫的返回值盛嘿。

首先是 Promise 的寫法。

function chainAnimationsPromise(elem, animations) {

  // 變量ret用來保存上一個(gè)動(dòng)畫的返回值
  let ret = null;

  // 新建一個(gè)空的Promise
  let p = Promise.resolve();

  // 使用then方法括袒,添加所有動(dòng)畫
  for(let anim of animations) {
    p = p.then(function(val) {
      ret = val;
      return anim(elem);
    });
  }

  // 返回一個(gè)部署了錯(cuò)誤捕捉機(jī)制的Promise
  return p.catch(function(e) {
    /* 忽略錯(cuò)誤次兆,繼續(xù)執(zhí)行 */
  }).then(function() {
    return ret;
  });

}

雖然 Promise 的寫法比回調(diào)函數(shù)的寫法大大改進(jìn),但是一眼看上去锹锰,代碼完全都是 Promise 的 API(then芥炭、catch等等),操作本身的語義反而不容易看出來恃慧。

接著是 Generator 函數(shù)的寫法园蝠。

function chainAnimationsGenerator(elem, animations) {

  return spawn(function*() {
    let ret = null;
    try {
      for(let anim of animations) {
        ret = yield anim(elem);
      }
    } catch(e) {
      /* 忽略錯(cuò)誤,繼續(xù)執(zhí)行 */
    }
    return ret;
  });

}

上面代碼使用 Generator 函數(shù)遍歷了每個(gè)動(dòng)畫痢士,語義比 Promise 寫法更清晰彪薛,用戶定義的操作全部都出現(xiàn)在spawn函數(shù)的內(nèi)部。這個(gè)寫法的問題在于怠蹂,必須有一個(gè)任務(wù)運(yùn)行器善延,自動(dòng)執(zhí)行 Generator 函數(shù),上面代碼的spawn函數(shù)就是自動(dòng)執(zhí)行器褥蚯,它返回一個(gè) Promise 對象挚冤,而且必須保證yield語句后面的表達(dá)式况增,必須返回一個(gè) Promise赞庶。

最后是 async 函數(shù)的寫法。

async function chainAnimationsAsync(elem, animations) {
  let ret = null;
  try {
    for(let anim of animations) {
      ret = await anim(elem);
    }
  } catch(e) {
    /* 忽略錯(cuò)誤澳骤,繼續(xù)執(zhí)行 */
  }
  return ret;
}

可以看到 Async 函數(shù)的實(shí)現(xiàn)最簡潔歧强,最符合語義,幾乎沒有語義不相關(guān)的代碼为肮。它將 Generator 寫法中的自動(dòng)執(zhí)行器摊册,改在語言層面提供,不暴露給用戶颊艳,因此代碼量最少茅特。如果使用 Generator 寫法,自動(dòng)執(zhí)行器需要用戶自己提供棋枕。`

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末白修,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子重斑,更是在濱河造成了極大的恐慌兵睛,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,366評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異祖很,居然都是意外死亡笛丙,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評論 3 395
  • 文/潘曉璐 我一進(jìn)店門假颇,熙熙樓的掌柜王于貴愁眉苦臉地迎上來胚鸯,“玉大人,你說我怎么就攤上這事笨鸡〈懒眨” “怎么了?”我有些...
    開封第一講書人閱讀 165,689評論 0 356
  • 文/不壞的土叔 我叫張陵镜豹,是天一觀的道長傲须。 經(jīng)常有香客問我,道長趟脂,這世上最難降的妖魔是什么泰讽? 我笑而不...
    開封第一講書人閱讀 58,925評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮昔期,結(jié)果婚禮上已卸,老公的妹妹穿的比我還像新娘。我一直安慰自己硼一,他們只是感情好累澡,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,942評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著般贼,像睡著了一般愧哟。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上哼蛆,一...
    開封第一講書人閱讀 51,727評論 1 305
  • 那天蕊梧,我揣著相機(jī)與錄音,去河邊找鬼腮介。 笑死肥矢,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的叠洗。 我是一名探鬼主播甘改,決...
    沈念sama閱讀 40,447評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼灭抑!你這毒婦竟也來了十艾?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,349評論 0 276
  • 序言:老撾萬榮一對情侶失蹤名挥,失蹤者是張志新(化名)和其女友劉穎疟羹,沒想到半個(gè)月后主守,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,820評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡榄融,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,990評論 3 337
  • 正文 我和宋清朗相戀三年参淫,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片愧杯。...
    茶點(diǎn)故事閱讀 40,127評論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡涎才,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出力九,到底是詐尸還是另有隱情耍铜,我是刑警寧澤,帶...
    沈念sama閱讀 35,812評論 5 346
  • 正文 年R本政府宣布跌前,位于F島的核電站棕兼,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏抵乓。R本人自食惡果不足惜伴挚,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,471評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望灾炭。 院中可真熱鬧茎芋,春花似錦、人聲如沸蜈出。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,017評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽铡原。三九已至偷厦,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間眷蜈,已是汗流浹背沪哺。 一陣腳步聲響...
    開封第一講書人閱讀 33,142評論 1 272
  • 我被黑心中介騙來泰國打工沈自, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留酌儒,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,388評論 3 373
  • 正文 我出身青樓枯途,卻偏偏與公主長得像忌怎,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子酪夷,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,066評論 2 355

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

  • 異步編程對JavaScript語言太重要榴啸。Javascript語言的執(zhí)行環(huán)境是“單線程”的,如果沒有異步編程晚岭,根本...
    呼呼哥閱讀 7,311評論 5 22
  • 含義 async函數(shù)是Generator函數(shù)的語法糖鸥印,它使得異步操作變得更加方便。 寫成async函數(shù),就是下面這...
    oWSQo閱讀 1,993評論 0 2
  • async 函數(shù) 含義 ES2017 標(biāo)準(zhǔn)引入了 async 函數(shù)库说,使得異步操作變得更加方便狂鞋。 async 函數(shù)是...
    huilegezai閱讀 1,259評論 0 6
  • 簡介 基本概念 Generator函數(shù)是ES6提供的一種異步編程解決方案,語法行為與傳統(tǒng)函數(shù)完全不同潜的。Genera...
    oWSQo閱讀 515評論 0 2
  • 這個(gè)時(shí)代私密的思考是不被允許的 我們享受著放棄自我所帶來的快樂 徬佛我們生而一體
    憨憨爹閱讀 127評論 0 0