Promise.all 和 Promise.allSettled

本文将探讨处理多个Promise的方法:Promise.all 与 Promise.allSettled 之间的区别以及何时使用它们。

1. Promise.all:高期望

Promise.all 是一种广泛使用的方法,它接受一个 Promise 数组,并返回一个新的 Promise。当数组中的所有 Promise 都成功时,新的 Promise 也成功;当数组中的任何一个 Promise 失败时,新的 Promise 就会失败。换句话说,它期望所有 Promise 要么成功,要么失败,然后根据情况提供一个结果。

让我们来看一个示例:

javascript 复制代码
const promises = [

  fetch('https://api.example.com/data1'),

  fetch('https://api.example.com/data2'),

  fetch('https://api.example.com/data3'),

];

  


Promise.all(promises)

  .then((results) => {

    // 处理成功的结果

  })

  .catch((error) => {

    // 处理任何错误

  });

在这个示例中,如果任何请求失败,整个Promise.all都会失败,并且你需要在catch块中处理错误。

2. Promise.allSettled:接受现实

与此不同,Promise.allSettled 是 JavaScript Promise API 的较新添加。它也接受一个 Promise 数组,但不会在任何 Promise 拒绝时中断。相反,它会等待所有 Promise 都 "settled"(无论是成功还是失败),并返回一个包含每个 Promise 结果的对象数组。

下面是如何使用Promise.allSettled:

javascript 复制代码
const promises = [

  fetch('https://api.example.com/data1'),

  fetch('https://api.example.com/data2'),

  fetch('https://api.example.com/data3'),

];

  


Promise.allSettled(promises)

  .then((results) => {

    results.forEach((result) => {

      if (result.status === 'fulfilled') {

        // 处理成功的结果

        console.log('已完成:', result.value);

      } else {

        // 处理错误

        console.log('已拒绝:', result.reason);

      }

    });

  });

在这个示例中,即使某些Promise被拒绝,Promise.allSettled仍然会成功,并提供有关每个Promise状态的信息。这在你需要独立了解每个Promise的结果(无论成功或失败)时非常有用。

3. 何时使用

  1. Promise.all: 当你需要所有的 Promise 都成功才能被认为是成功操作,如果有一个 Promise 失败,就中止整个操作。

  2. Promise.allSettled: 当你希望等待所有Promise完成,并需要知道每个Promise的结果,无论成功与否。这在需要单独报告每个 Promise 的状态时非常有用。

4. 总结

Promise.all 和 Promise.allSettled 都是处理多个Promise 的强大工具,选择取决于具体的使用情况,以及是否需要一刀切的行为(Promise.all)或需要单独处理每个 Promise 的结果(Promise.allSettled)。

希望本文对您有所帮助!

相关推荐
前端梭哈攻城狮2 分钟前
uniapp图片上传添加水印/压缩/剪裁
前端·javascript·vue.js
天涯学馆3 分钟前
前后端分离的 API 设计:技术深度剖析
前端·javascript·面试
爱编程的喵4 分钟前
深入理解JavaScript原型机制:从Java到JS的面向对象编程之路
java·前端·javascript
独立开阀者_FwtCoder4 分钟前
Cursor 1.0 重磅发来袭(毛骨悚然,开始学习你如何编码)
前端·javascript·github
五点六六六10 分钟前
一些关于TreeShaking的AST的理解
前端·javascript·前端工程化
海盐泡泡龟1 小时前
“组件、路由懒加载”,在 Vue3 和 React 中分别如何实现? (copy)
前端·javascript·react.js
coding随想1 小时前
深入浅出WebGL:在浏览器中解锁3D世界的魔法钥匙
javascript
踢足球的,程序猿1 小时前
从 Vue 2.0 进阶到 Vue 3.0 的核心技术解析指南
前端·javascript·vue.js·前端框架·html
阿山同学.2 小时前
AWS 亚马逊 S3存储桶直传 前端demo 复制即可使用
前端·javascript·aws
sunly_2 小时前
Flutter:导航固定背景图,滚动时导航颜色渐变
android·javascript·flutter