JS手写代码篇---手写promise.all

5、promise.all

首先promise.all的作用:

all主要用来解决多个异步操作的调用问题,类似于Promise.all的功能。

复制代码
        function p1 (){
            return new Promise((resolve , reject) => {
                setTimeout(() => {
                    resolve('p1 resolved');
                }, 1000);
            })
        }
        function p2 (){
            return new Promise((resolve , reject) => {
                resolve('p2 resolved');
            })
        }
        Promise.all([p1(), p2()]).then((results) => {
            console.log(results); // ['p1 resolved', 'p2 resolved']
        }).catch((error) => {
            console.error(error);
        });

因为p1是有setTimeout的,所以p1会在1秒后执行,而p2是立即执行的,所以p1和p2的结果会在1秒后一起输出。但是我们使用了 Promise.all,所以它会等待所有的 Promise 都完成后再执行 then 方法。这就是为什么结果是 ['p1 resolved', 'p2 resolved'],而不是 ['p2 resolved', 'p1 resolved']。

开始手写:

  • all方法是静态方法,所以不需要实例化

  • all方法的返回值是一个新的promise对象,这个新的promise对象的结果是一个数组,数组的长度和传入的数组长度一致

  • 如果有一个失败,就直接reject

  • 如果所有的都成功,就resolve一个数组,数组的长度和传入的数组长度一致

  • for循环一下子就执行完了,但是有异步执行的操作,我们要设一个计数器,当数组的长度和传入的数组长度一致的时候,就要reject

    复制代码
          static all(array){
            let res = []; //存放结果的数组
            let count = 0; // 计数器
            return new Commitment((resolve , reject) => {
            // 添加数据的函数
            function addData (key , value){
              res[key] = value;
              count++; // 每添加一个数据就加1
              // 如果计数器等于数组长度,就说明所有数据都添加完了
              if(count === array.length){
                // 说明所有数据都添加完了,就resolve
                resolve(res);//保证所有数据都添加完了才resolve,因为for循环一下子就执行完了,但是有异步执行的操作
              }
            }
              // 循环
              for(let i = 0 ; i < array.length ; i++){
                let cur = array[i];
                // 判断是否是普通值
                if(cur instanceof Commitment){
                  // 如果不是,执行promise,注意如果有一个失败,就直接reject
                  cur.then((value) => addData(i , value) , (error) => reject(error));
                }else {
                  // 如果是,直接添加到结果数组中
                  addData(i , cur);
                }
              }
    
            })
    
    
          }

总结一下:promise.all方法主要是处理多个异步的调用问题,传入一个数组,返回的是新的promise对象,它是静态方式。所以传入数组后我们循环遍历了这个数组,如果它是普通值,如果是就要直接添加到结果数组里卖弄,如果不是,then等待结果,只要有一个错误,那么就直接reject,最后当结果数组的长度和传入数组的长度相同的时候就要resolve啦~~

相关推荐
雨中散步撒哈拉几秒前
3、做中学 | 二年级上期 Golang数据类型和常量/变量声明使用
开发语言·后端·golang
YuTaoShao5 分钟前
Java八股文——Redis「淘汰删除篇」
java·开发语言·redis
意疏8 分钟前
全面掌握 C++ 基础:关键特性与进化
开发语言·c++
ew4521819 分钟前
【VUE】某时间某空间占用情况效果展示,vue2+element ui实现。场景:会议室占用、教室占用等。
前端·vue.js·ui·elementui
唐人街都是苦瓜脸25 分钟前
Vue 3中unref的写法
前端·javascript·vue.js
love530love41 分钟前
【笔记】解决部署国产AI Agent 开源项目 MiniMax-M1时 Hugging Face 模型下载缓存占满 C 盘问题:更改缓存位置全流程
开发语言·人工智能·windows·笔记·python·缓存·uv
猫老板的豆42 分钟前
react-activation 组件级缓存解决方案
javascript·react.js·缓存
狐凄42 分钟前
Python实例题:基于 Apache Kafka 的实时数据流处理平台
开发语言·python
前端小菜鸟吖1 小时前
2025年最新版HTML5超完整教程
前端·html
中微子1 小时前
WeUI-Uploader 源码深度解析:大厂必考的上传组件实现
前端