Promise

Promise 是異步編程的一種解決方案,比傳統(tǒng)的解決方案——回調(diào)函數(shù)和事件——更合理和更強大矮湘。它由社區(qū)最早提出和實現(xiàn)刹衫,ES6 將其寫進了語言標(biāo)準(zhǔn)醋寝,統(tǒng)一了用法搞挣,原生提供了Promise對象。

基本用法

ES6 規(guī)定音羞,Promise對象是一個構(gòu)造函數(shù)囱桨,用來生成Promise實例。下面代碼創(chuàng)造了一個Promise實例嗅绰。

new Promise(function(resolve,reject){
       console.log('Promise');
       resolve();
}).then(function(){
        console.log('resolved.');
})
console.log('Hi!');

// Promise
// Hi!
// resolved

錯誤捕獲

promise.then(function(data) {
          // 成功時執(zhí)行的代碼塊
  }, function(err) {
         // 失敗時執(zhí)行的代碼塊
  });
// 等同于
promise.then(function(data) { //cb
          // 成功時執(zhí)行的代碼塊
  }).catch(function(err) {
         // 失敗時執(zhí)行的代碼塊
  });

其他promise方法

promise.all()【返回一個 Promise實例舍肠,此實例在 iterable 參數(shù)內(nèi)所有的 promise 都“完成(resolved)”或參數(shù)中不包含 promise 時回調(diào)完成(resolve);如果參數(shù)中 promise 有一個失敯煜荨(rejected)貌夕,此實例回調(diào)失敗(reject)民镜,失敗原因的是第一個失敗 promise 的結(jié)果

Promise.all([p1,p2,p3]).then(res=>{
            console.log(res)
     })

promise.race()【返回一個 promise啡专,一旦迭代器中的某個promise解決或拒絕,返回的 promise就會解決或拒絕制圈∶峭】

var promise1 = new Promise(function(resolve, reject) {
         setTimeout(resolve, 500, 'one');
});

var promise2 = new Promise(function(resolve, reject) {
        setTimeout(resolve, 100, 'two');
});

Promise.race([promise1, promise2]).then(function(value) {
        console.log(value);
});

// two

async/awite

ES2017 (ES7)標(biāo)準(zhǔn)引入了 async 函數(shù),使得異步操作變得更加方便鲸鹦。async 函數(shù)是什么慧库?一句話,它就是 Generator 函數(shù)的語法糖馋嗜。使異步代碼變成同步執(zhí)行齐板。

基本用法

async函數(shù)返回一個 Promise 對象,可以使用then方法添加回調(diào)函數(shù)葛菇。當(dāng)函數(shù)執(zhí)行的時候甘磨,一旦遇到await就會先返回,等到異步操作完成眯停,再接著執(zhí)行函數(shù)體內(nèi)后面的語句济舆。

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 毫秒以后,輸出hello world莺债。

返回Promise對象

async function f() {
  return 'hello world';
}

f().then(v => console.log(v))
// "hello world"

注意點:

  1. async函數(shù)和普通函數(shù)一樣按順序執(zhí)行滋觉,同時,在執(zhí)行到await語句時齐邦,返回一個Promise對象

  2. await可以理解為將async函數(shù)掛起椎侠,直到等待的Promise被fulfill或者reject,再繼續(xù)執(zhí)行之后的代碼

  3. async函數(shù)的返回值和普通Promise沒有區(qū)別

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末措拇,一起剝皮案震驚了整個濱河市肺蔚,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖宣羊,帶你破解...
    沈念sama閱讀 221,695評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異汰蜘,居然都是意外死亡仇冯,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,569評論 3 399
  • 文/潘曉璐 我一進店門族操,熙熙樓的掌柜王于貴愁眉苦臉地迎上來苛坚,“玉大人,你說我怎么就攤上這事色难∑貌眨” “怎么了?”我有些...
    開封第一講書人閱讀 168,130評論 0 360
  • 文/不壞的土叔 我叫張陵枷莉,是天一觀的道長娇昙。 經(jīng)常有香客問我,道長笤妙,這世上最難降的妖魔是什么冒掌? 我笑而不...
    開封第一講書人閱讀 59,648評論 1 297
  • 正文 為了忘掉前任,我火速辦了婚禮蹲盘,結(jié)果婚禮上股毫,老公的妹妹穿的比我還像新娘。我一直安慰自己召衔,他們只是感情好铃诬,可當(dāng)我...
    茶點故事閱讀 68,655評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著苍凛,像睡著了一般趣席。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上毫深,一...
    開封第一講書人閱讀 52,268評論 1 309
  • 那天吩坝,我揣著相機與錄音,去河邊找鬼哑蔫。 笑死钉寝,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的闸迷。 我是一名探鬼主播嵌纲,決...
    沈念sama閱讀 40,835評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼腥沽!你這毒婦竟也來了逮走?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,740評論 0 276
  • 序言:老撾萬榮一對情侶失蹤今阳,失蹤者是張志新(化名)和其女友劉穎师溅,沒想到半個月后茅信,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,286評論 1 318
  • 正文 獨居荒郊野嶺守林人離奇死亡墓臭,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,375評論 3 340
  • 正文 我和宋清朗相戀三年蘸鲸,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片窿锉。...
    茶點故事閱讀 40,505評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡酌摇,死狀恐怖说贝,靈堂內(nèi)的尸體忽然破棺而出脆炎,到底是詐尸還是另有隱情,我是刑警寧澤拳芙,帶...
    沈念sama閱讀 36,185評論 5 350
  • 正文 年R本政府宣布洼滚,位于F島的核電站埂息,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏判沟。R本人自食惡果不足惜耿芹,卻給世界環(huán)境...
    茶點故事閱讀 41,873評論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望挪哄。 院中可真熱鬧吧秕,春花似錦、人聲如沸迹炼。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,357評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽斯入。三九已至砂碉,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間刻两,已是汗流浹背增蹭。 一陣腳步聲響...
    開封第一講書人閱讀 33,466評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留磅摹,地道東北人滋迈。 一個月前我還...
    沈念sama閱讀 48,921評論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像户誓,于是被迫代替她去往敵國和親饼灿。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,515評論 2 359

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

  • Promise 對象 Promise 的含義 Promise 是異步編程的一種解決方案帝美,比傳統(tǒng)的解決方案——回調(diào)函...
    neromous閱讀 8,710評論 1 56
  • 一. Callback (回調(diào)函數(shù)) 1.定義:把函數(shù)當(dāng)作變量傳到另一個函數(shù)里皆疹,傳進去之后執(zhí)行甚至返回等待之后的...
    hutn閱讀 1,532評論 0 2
  • 目錄:Promise 的含義基本用法Promise.prototype.then()Promise.prototy...
    BluesCurry閱讀 1,494評論 0 8
  • 單線程 JavaScript是一門單線程的語言创译,被廣泛應(yīng)用于瀏覽器和頁面DOM元素交互,自從Node.js出現(xiàn)后墙基,...
    JunChow520閱讀 801評論 0 3
  • 一、Promise的含義 Promise在JavaScript語言中早有實現(xiàn)刷喜,ES6將其寫進了語言標(biāo)準(zhǔn)残制,統(tǒng)一了用法...
    Alex灌湯貓閱讀 827評論 0 2