【Promise.allSettled】手写Promise.allSettled方法

Promise.allSettled是Promise对象的一个静态方法
参数是一个可迭代对象,一般是一个Promise数组
Promise.allSettled()方法返回一个Promise对象,当所有给定的 promise对象都已经fulfilled或rejected后,返回的Promise对象能拿到一个对象数组,每个对象表示对应的 promise 结果数据以及状态。

当您有多个彼此不依赖的异步任务成功完成时,或者您总是想知道每个promise的结果时,通常使用它。

const pro = new Promise((resolve, reject) => {
  setTimeout(() => {
    reject(3);
  }, 1000);
});
Promise.allSettled([pro, Promise.resolve(1), Promise.reject(2)]).then(
  (data) => {
    console.log(data);
  }
);

打印结果

[
  { status: 'rejected', reason: 3 },
  { status: 'fulfilled', value: 1 },
  { status: 'rejected', reason: 2 }
]

手写Promise.allSettled代码

Promise.myAllSettled = function (proms) {
  return new Promise((resolve, reject) => {
    let resolvedCount = 0;
    let count = 0;
    const results = [];
    for (const prom of proms) {
      let i = count;
      count++;
      Promise.resolve(prom)
        .then(
          (data) => {
            resolvedCount++;
            results[i] = {
              status: "fullfilled",
              value: data,
            };
          },
          (reason) => {
            resolvedCount++;
            results[i] = {
              status: "rejected",
              reason,
            };
          }
        )
        .finally(() => {
          if (resolvedCount >= count) {
            resolve(results);
          }
        });
    }
  });
};

const pro = new Promise((resolve, reject) => {
  setTimeout(() => {
    reject(3);
  }, 1000);
});

Promise.allSettled([pro, Promise.resolve(1), Promise.reject(2)]).then(
  (data) => {
    console.log(data);
  }
);

Promise.myAllSettled([pro, Promise.resolve(1), Promise.reject(2)]).then(
  (data) => {
    console.log(data);
  }
);

我的github有更多的前端手写代码。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值