【前端手撕】promise.all

碎碎念

好今天起的有点晚了。这段时间都不怎么休息好,今早起来又看到没接的电话,自从上次说了这个问题之后就有点ptsd了。今晚吃个褪黑素吧。

Promise.all

Promise.all()是JavaScript中的一个静态方法,它接受一个Promise实例的数组作为参数,并返回一个新的Promise实例。这个新的Promise实例的状态将在所有传递的Promise实例都已完成时变为已完成,并且它的完成值将是一个包含所有传递Promise实例完成值的数组。

当所有传递的Promise实例都已完成时,then()方法指定的回调函数将被调用,并且它的参数将是一个包含所有Promise实例完成值的数组。

如果其中任意一个Promise实例的状态变为已失败,则Promise.all()方法返回的Promise实例的状态也将变为已失败,并且将调用catch()方法指定的回调函数。

javascript 复制代码
function promiseAll(promises) {
    //promise.all返回的是一个新的Promise对象
    // 当所有Promise对象都resolve时,新的Promise对象也会resolve
    // 当有一个Promise对象reject时,新的Promise对象也会reject
    return new Promise((resolve, reject) => {
        const res = []
        let len = promises.length
        if (!len) return resolve(res)
            
        // 把单独的promise对象的then方法返回的结果加到res数组中
        function fulfill(index, value) {
            res[index] = value
            len--
            if (!len) return resolve(res)
        }
        
        // 遍历promises数组
        promises.forEach((promise, index) => {
            Promise.resolve(promise).then(value => fulfill(index, value)).catch(error => reject(error))
        })
    })
}
相关推荐
lichenyang4531 小时前
动态加载 vs 延迟加载:为什么 demo 里「延迟」看起来没效果?
前端
cypking1 小时前
从零搭建 Claude Code + Chrome MCP 浏览器自动化:前端 E2E 端到端测试完整教程(包含增量测试)
前端·chrome·自动化
Levi_J1 小时前
Vue2 升级 Vue3 项目实战
前端
前端拷贝猿1 小时前
扫码领券功能需求分析
前端
前端拷贝猿1 小时前
设备活动弹窗功能需求分析
前端
飞天狗1111 小时前
零基础JavaWeb入门——第五课第一小节:九大内置对象 · 第1个:request(请求对象)
java·开发语言·前端·后端·servlet
a15108416932 小时前
记一次大模型探索
java·服务器·前端
石山代码2 小时前
变量与解构
开发语言·前端·javascript
888CC++2 小时前
箭头函数(ES6)
前端·javascript·es6