Promise.all()与Promise.allSettled()和Promise.race() 有什么区别与联系

Promise.all()与Promise.allSettled()和Promise.race() 有什么区别与联系

Promise.all(), Promise.allSettled(), 和 Promise.race() 都是处理多个 Promise 对象的方法,但它们各自的行为和用途有所不同。

Promise.all()

Promise.all() 方法接受一个可迭代对象(如数组)作为参数,该对象中的每个成员都是一个 Promise。它返回一个新的 Promise 实例,这个实例在所有输入的 Promise 都成功(resolved)后才解析,并且解析值是一个包含所有输入 Promise 解析值的数组。

如果输入的任何一个 Promise 失败(rejected),那么 Promise.all() 返回的 Promise 会立即失败,并且失败的原因是第一个失败的 Promise 的原因。

示例:

javascript 复制代码
const promise1 = Promise.resolve(3);
const promise2 = Promise.reject(new Error('Promise Error'));
const promise3 = Promise.resolve(7);

Promise.all([promise1, promise2, promise3])
  .then(values => console.log(values))
  .catch(error => console.error(error));
// 输出: Error: Promise Error

Promise.allSettled()

Promise.allSettled() 类似于 Promise.all(),它也接受一个包含多个 Promise 的可迭代对象。但是,即使其中的一个或多个 Promise 被拒绝,Promise.allSettled() 也会等待所有的 Promise 完成,并返回一个包含每个 Promise 的最终状态的对象数组。

每个对象都有一个 status 属性,表示 Promise 的状态("fulfilled" 或 "rejected"),以及一个 value 或 reason 属性,分别对应于 fulfilled 或 rejected 的结果。

示例:

javascript 复制代码
 const promise1 = Promise.resolve(3);
const promise2 = Promise.reject(new Error('Promise Error'));
const promise3 = Promise.resolve(7);

Promise.allSettled([promise1, promise2, promise3])
  .then(results => {
    results.forEach(result => {
      console.log(`${result.status}: ${result.value !== undefined ? result.value : result.reason}`);
    });
  });
// 输出:
// fulfilled: 3
// rejected: Error: Promise Error
// fulfilled: 7

Promise.race()

Promise.race() 接受一个可迭代对象,其中每个成员也是一个 Promise。它返回一个新的 Promise,这个 Promise 会在可迭代对象中的任何一个 Promise 解析或拒绝时立即解析或拒绝。换句话说,Promise.race() 返回的 Promise 会被第一个完成的 Promise 的结果所决定。

javascript 复制代码
const promise1 = new Promise(resolve => {
  setTimeout(() => resolve('first'), 1000);
});
const promise2 = new Promise(resolve => {
  setTimeout(() => resolve('second'), 500);
});

Promise.race([promise1, promise2]).then(value => {
  console.log(value); // 输出: 'second'
});

总结

  • Promise.all(): 所有输入的 Promise 成功后才成功,任意一个失败则立即失败
  • Promise.allSettled(): 等待所有输入的 Promise 完成,无论成功还是失败,并返回一个包含所有状态的对象数组。
  • Promise.race(): 返回第一个完成的 Promise 的结果,无论成功还是失败。
相关推荐
华仔啊8 分钟前
JavaScript 如何准确判断数据类型?5 种方法深度对比
前端·javascript
listhi52011 分钟前
对LeNet-5的matlab实现,识别MINST手写数字集
开发语言·matlab
qq_4335545415 分钟前
C++ manacher(求解回文串问题)
开发语言·c++·算法
csbysj202020 分钟前
Chart.js 饼图:全面解析与实例教程
开发语言
浩瀚地学27 分钟前
【Java】常用API(二)
java·开发语言·经验分享·笔记·学习
毕设十刻28 分钟前
基于Vue的迅读网上书城22f4d(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
程序员小寒28 分钟前
从一道前端面试题,谈 JS 对象存储特点和运算符执行顺序
开发语言·前端·javascript·面试
七夜zippoe38 分钟前
事件驱动架构:构建高并发松耦合系统的Python实战
开发语言·python·架构·eda·事件驱动
古城小栈1 小时前
Rust Trait 敲黑板
开发语言·rust
爱健身的小刘同学1 小时前
Vue 3 + Leaflet 地图可视化
前端·javascript·vue.js