ES6 Promise all 的实现

摘要:Promise 是ES6语法标准里的新定义,一般用来处理异步方法的同步执行。本文主要介绍Promise all的用法和实现。加入有以下场景:我有5个异步方法

Promise 是ES6语法标准里的新定义,一般用来处理异步方法的同步执行。本文主要介绍Promise all的用法和实现。
加入有以下场景:我有5个异步方法,需要等到这5个方法执行结束之后再执行下一步,如果其中有一个出错,则进入到catch方法里。具体实现如下:

function promiseAll(arr){
    return new Promise((resolve, reject) => {
        const result = [];
        let i = 0;
        function next(promise){
            if( i > arr.length - 1){
                return resolve(result);
            }
            promise().then(res => {
                const end = new Date().valueOf();
                const diff = end - start;
                console.log(i, diff)
                result.push(res);
                next(arr[++i]);
            }).catch(err => {
                return resolve(err);
            })
        }
        next(arr[i]);
    });
};

const promiseList = [1,2,3,4,5].map(one => {
    return () => {
         return new Promise((resolve, reject) => {
            setTimeout(() => {
                resolve(one);
            }, 1000);
        })
    }
});

const start = new Date().valueOf();
promiseAll(promiseList).then(res => {
    const end = new Date().valueOf();
    console.log(res, end - start)
});
// [1, 2, 3, 4, 5] 15000

对性能要求比较高的朋友会发现,这个是一个一个按顺序执行的,而且如果传进去的数组元素不是promise的话,会报错(没有then方法)。
并发执行实现方式如下:

function promiseAll(arr){
    const result = [];
    return new Promise((resolve, reject) => {
        for(let i = 0; i < arr.length; i++){
            let p = arr[i];
            if(p instanceof Promise){   
            } else {
              p = Promise.resolve(p);
            }
            p.then((res) => {
                result[i] = res;
            }).catch(err => {
                return reject(err);
            })
        }
        return resolve(result);
    })
}
const input = [1,2,3,4,5];
promiseAll(input).then(res => {
    console.log(res);
}).catch(error => {
    console.log(error);
})


本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!

链接: https://shenqiku.cn/article/FLY_7327