Promise.all 的原理
生活随笔
收集整理的這篇文章主要介紹了
Promise.all 的原理
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
// all的原理
Promise.all = function(values){return new Promise((resolve,reject)=>{let results = []; // 結(jié)果數(shù)組let i = 0;let processData = (value,index)=>{results[index] = value;// 當(dāng)成功的個(gè)數(shù) 和 當(dāng)前的參數(shù)個(gè)數(shù)相等就把結(jié)果拋出去if(++i === values.length){resolve(results);}}for(let i = 0 ; i< values.length;i++){let current = values[i]; // 拿到數(shù)組中每一項(xiàng)// 判斷是不是一個(gè)promiseif((typeof current === 'object' && current !==null)|| typeof current == 'function'){// 如果是promiseif(typeof current.then == 'function'){// 就調(diào)用這個(gè)promise的then方法,把結(jié)果和索引對(duì)應(yīng)上,如果任何一個(gè)失敗了返回的proimise就是一個(gè)失敗的promisecurrent.then(y=>{processData(y,i);},reject)}else{processData(current,i);}}else{processData(current,i);}}});
}
?
轉(zhuǎn)載于:https://www.cnblogs.com/guangzhou11/p/11322644.html
總結(jié)
以上是生活随笔為你收集整理的Promise.all 的原理的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 修改Thickbox,预加载图片和点击图
- 下一篇: Promise.race 的原理