ES6之Promise的静态方法

34 阅读1分钟

ES6之Promise的静态方法

为什么要有静态方法,主要是为了对多个 Promise 进行更好的控制。
Promise.resove() ,Promise.reject() 可以返回一个成功和失败的 Promise 。
Promise.all() 只有全部成功才会成功,返回的是失败的数组 Promise.any()有一个成功就算成功,返回的是成功的数组
Promise.allSettled() 全部已决就算成功,不会失败
Promise.race() 最先已决的状态,可能成功,可能失败 如果想解决多个异步任务,可以像下面这个例子:

// 做饭
function cook() {
  return new Promise((resolve, reject) => {
    console.log('邓哥打开了电饭煲');
    setTimeout(() => {
      if (Math.random() < 0.5) {
        resolve('饭已ok');
      } else {
        reject('做饭却忘了加水,米饭变成了爆米花');
      }
    }, 2000);
  });
}

// 洗衣服
function wash() {
  return new Promise((resolve, reject) => {
    console.log('邓哥打开了洗衣机');
    setTimeout(() => {
      if (Math.random() < 0.5) {
        resolve('衣服已经洗好');
      } else {
        reject('洗衣服时停水了,洗了个寂寞');
      }
    }, 2500);
  });
}

// 打扫卫生
function sweep() {
  return new Promise((resolve, reject) => {
    console.log('邓哥打开了扫地机器人');
    setTimeout(() => {
      if (Math.random() < 0.5) {
        resolve('地板扫的非常干净');
      } else {
        reject('扫地机器人被哈士奇一爪掀翻了');
      }
    }, 3000);
  });
}

Promise.allSettled([cook(), wash(), sweep()]).then((result) => {
  // 处理汇总结果

  const report = result
    .map((r) => (r.status === 'fulfilled' ? r.value : r.reason))
    .join(';');
  console.log(report);
});