【promise-05】promise.all()與promise.race()

#promise.all()與promise.race()

Promise.all()方法可以把多個promise實(shí)例 包裝成一個新的promise實(shí)例

Promise.all([ promise1, promise2 ]): Promise.all()接收的是一個數(shù)組祈远,數(shù)組中的每一項都是promise實(shí)例呆万,最終返回的也是一個promise實(shí)例。

它分三種情況:

  1. 如果數(shù)組中的所有實(shí)例都決議為成功的話车份,這時候promise.all()就會決議為成功谋减,并且所有這里promise的resolve帶的參數(shù)都會組合成一個數(shù)組傳遞給我們,且順序一一對應(yīng)扫沼。
function getData1() {
  return new Promise((resolve, reject) => {
    setTimeout(() => {
      console.log('第一條數(shù)據(jù)加載成功');
      resolve('data1');
    }, 1000);
  });
}

function getData2() {
  return new Promise((resolve, reject) => {
    setTimeout(() => {
      console.log('第二條數(shù)據(jù)加載成功');
      resolve('data2');
    }, 1000);
  });
}

function getData3() {
  return new Promise((resolve, reject) => {
    setTimeout(() => {
      console.log('第三條數(shù)據(jù)加載成功');
      resolve('data3');
    }, 1000);
  });
}

function getData4() {
  return new Promise((resolve, reject) => {
    setTimeout(() => {
      console.log('第四條數(shù)據(jù)加載成功');
      resolve('data4');
    }, 500);
  });
}

let p = Promise.all([getData1(),getData2(),getData3(),getData4()]);

//arr 為promise數(shù)組所返回的數(shù)組
p.then(arr => {
  console.log(arr); 
});

console.log(arr); 結(jié)果為["data1","data2","data3","data4"]

  1. 當(dāng)數(shù)組中有任意一個promise決議為失敗的時候出爹,那promise.all()就會決議為失敗,并且把決議為失敗的promise的錯誤在傳遞過來

例如getData4()是錯誤的:

function getData4() {
  return new Promise((resolve, reject) => {
    setTimeout(() => {
      // console.log('第四條數(shù)據(jù)加載成功');
      reject('data4 err');
    }, 500);
  });
}

let p = Promise.all([getData1(),getData2(),getData3(),getData4()]);

p.then(arr => {
  console.log(arr); 
}, e => {
  console.log(e);
});

這里的promise實(shí)例直接決議為失敗充甚,并且吧getData4中reject傳遞的信息傳遞了回來以政。 console.log(e);打印的就是 ‘data4 err’

  1. 當(dāng)數(shù)組為空promise.all()就會決議為成功
let p = Promise.all([]);

p.then(() => {
  console.log('dfsafd');
}, e => {
  console.log(e);
});

promise.race()

與promise.all對應(yīng)的race方法接收的也是一個數(shù)組伴找,里面也都是promise實(shí)例盈蛮,與all方法不同的是,race里面技矮,只要有一個promise決議為成功或者失敗抖誉,這個promise.race()返回的promise實(shí)例,也會是對應(yīng)的成功或者失敗衰倦,并把值傳遞過來袒炉。
Promise.race([p1, p2, p3])里面哪個結(jié)果獲得的快,就返回哪個結(jié)果樊零,不管結(jié)果本身是成功狀態(tài)還是失敗狀態(tài)

我們把getData1()的定時器改為半秒,

function getData1() {
  return new Promise((resolve, reject) => {
    setTimeout(() => {
      console.log('第一條數(shù)據(jù)加載失敗');
      reject('err');
    }, 500);
  });
}

function getData2() {
  return new Promise((resolve, reject) => {
    setTimeout(() => {
      console.log('第二條數(shù)據(jù)加載成功');
      resolve('data2');
    }, 1000);
  });
}

function getData3() {
  return new Promise((resolve, reject) => {
    setTimeout(() => {
      console.log('第三條數(shù)據(jù)加載成功');
      resolve('data3');
    }, 1000);
  });
}

let p = Promise.race([getData1(),getData2(),getData3()]);

p.then(data => {
    console.log(data);
}, e => {
    console.log(e); 
})

我們會立即輸出err我磁,輸出結(jié)果為

第一條數(shù)據(jù)加載失敗
err
第二條數(shù)據(jù)加載成功
第三條數(shù)據(jù)加載成功

需要注意的是孽文,promise.race()接收空數(shù)組的話,什么反應(yīng)也不會有夺艰。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末芋哭,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子郁副,更是在濱河造成了極大的恐慌减牺,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,042評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件存谎,死亡現(xiàn)場離奇詭異拔疚,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)既荚,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評論 2 384
  • 文/潘曉璐 我一進(jìn)店門稚失,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人固以,你說我怎么就攤上這事墩虹≈鼋恚” “怎么了憨琳?”我有些...
    開封第一講書人閱讀 156,674評論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長旬昭。 經(jīng)常有香客問我篙螟,道長,這世上最難降的妖魔是什么问拘? 我笑而不...
    開封第一講書人閱讀 56,340評論 1 283
  • 正文 為了忘掉前任遍略,我火速辦了婚禮,結(jié)果婚禮上骤坐,老公的妹妹穿的比我還像新娘绪杏。我一直安慰自己,他們只是感情好纽绍,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,404評論 5 384
  • 文/花漫 我一把揭開白布蕾久。 她就那樣靜靜地躺著,像睡著了一般拌夏。 火紅的嫁衣襯著肌膚如雪僧著。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,749評論 1 289
  • 那天障簿,我揣著相機(jī)與錄音盹愚,去河邊找鬼。 笑死站故,一個胖子當(dāng)著我的面吹牛皆怕,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 38,902評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼愈腾,長吁一口氣:“原來是場噩夢啊……” “哼朗兵!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起顶滩,我...
    開封第一講書人閱讀 37,662評論 0 266
  • 序言:老撾萬榮一對情侶失蹤余掖,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后礁鲁,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體盐欺,經(jīng)...
    沈念sama閱讀 44,110評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年仅醇,在試婚紗的時候發(fā)現(xiàn)自己被綠了冗美。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,577評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡析二,死狀恐怖粉洼,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情叶摄,我是刑警寧澤属韧,帶...
    沈念sama閱讀 34,258評論 4 328
  • 正文 年R本政府宣布,位于F島的核電站蛤吓,受9級特大地震影響宵喂,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜会傲,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,848評論 3 312
  • 文/蒙蒙 一锅棕、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧淌山,春花似錦裸燎、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至王浴,卻和暖如春脆炎,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背氓辣。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評論 1 264
  • 我被黑心中介騙來泰國打工秒裕, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人钞啸。 一個月前我還...
    沈念sama閱讀 46,271評論 2 360
  • 正文 我出身青樓几蜻,卻偏偏與公主長得像喇潘,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子梭稚,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,452評論 2 348

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