JavaScript 中使用Promise.all()方法经验技巧详解

 更新时间:2023年10月08日 09:06:02   作者:王大冶  
这篇文章主要为大家介绍了JavaScript 中使用Promise.all()方法经验技巧详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

JavaScript 中的 Promises 是什么?

如果你偶然发现了这篇文章,你可能已经对 promises 很熟悉了。但对于那些新接触 JavaScript 的人来说,我们来详细解释一下。

从本质上讲,Promise 对象表示异步操作的最终完成或失败。有趣的是,当 promise 被创建时,其值可能不会立即可用。

const promise = new Promise((resolve, reject) => {  
  // 一些异步操作  
  if (/* 操作成功 */) {    
    resolve(result);  
  } else {    
    reject(error);  
  }
});

它们有3种状态:

  • Pending(待定):这是初始状态,既没有实现也没有被拒绝。
  • Fulfilled(已实现):当 promise 成功完成并产生值时的状态。
  • Rejected(已拒绝):当发生错误并且 promise 中的操作不成功时的状态。

一旦 promise 被解决,你可以使用 .then() 来处理结果,使用 .catch() 来管理其执行过程中出现的任何错误。

promise  
  .then(result => {    
    console.log('成功:', result);  
  })  
  .catch(error => {    
    console.error('错误:', error);  
  });

理解 Promise.all()

当同时处理多个 promises 时,你可以利用内置的 Promise.all([]) 方法。此方法接受一个 promises 数组并返回一个统一的 promise。关键是,只有当所有输入的 promises 都成功解决时,这个组合的 promise 才会解决。如果其中一个失败,整个 promise 就会被拒绝。以下是一个例子:

const promise1 = fetch('https://api.example.com/data1');
const promise2 = fetch('https://api.example.com/data2');
const promise3 = fetch('https://api.example.com/data3');
Promise.all([promise1, promise2, promise3])  
  .then(values => {    
    console.log('所有数据已获取:', values);  
  })  
  .catch(error => {    
    console.error('发生错误:', error);  
  });

这种方法通常用于多个相关异步任务且其工作相互依赖的情况,因此我们希望在继续执行代码之前,所有异步任务都能成功。

揭示 Promise.allSettled()

使用 Promise.allSettled([]) 与 Promise.all([]) 类似,但不同之处在于它会等待所有输入的 promises 完成或被拒绝,并返回描述每个 promise 结果的对象数组。

const promise1 = Promise.resolve('成功 1');
const promise2 = Promise.reject('错误 2');
const promise3 = Promise.resolve('成功 3');
Promise.allSettled([promise1, promise2, promise3])
  .then(results => {
    results.forEach(result => {
      if(result.status === 'fulfilled') {
        console.log('成功取得值:', result.value);
      } else {
        console.error('因为原因被拒绝:', result.reason);
      }
    });
 });
//输出
// 成功取得值:成功 1
// 因为原因被拒绝:错误 2
// 成功取得值:成功 3

它通常用于处理不互相依赖的异步操作,你想知道每一个的结果。

为什么 Promise.allSettled() 更出色

总的来说,使用 Promise.allSettled() 而不是 Promise.all() 在大多数常见情况下都有其优势:

全面的结果信息

如果 promises 中的任何一个被拒绝,Promise.all() 的立即拒绝可能会使得确定其他 promises 的状态变得困难,尤其是当其他 promises 成功解决时。

使用 Promise.allSettled([]) 可以为你提供结果的完整画面。

优雅的错误处理

Promise.all() 的“快速失败”方法在你想继续进行,而其中一个失败时可能会受到限制,而 Promise.allSettled() 允许你单独处理每个 promise 的结果。

批量操作

当处理批量操作时,其中的单个操作是独立的,你可能不希望整个批次因操作失败而失败。

明智的决策

使用 Promise.allSettled() 后,你可以在获得所有 promises 的结果后做出更明智的决策。

例如,当你从不同的 API 获取数据,其中一个失败时,你可以决定是否继续处理数据或提供带有错误消息的通知。

增强的用户体验

通常,为用户提供必要的部分结果和错误通知要比使用某些通用消息使整个操作失败更好。

Promise.allSettled() 使这种方法易于实施。

总结

总之,Promise.all() 在某些情况下可能很有价值,但 Promise.allSettled() 为大多数场景提供了更灵活和更有韧性的方法,更多关于JavaScript Promise.all的资料请关注脚本之家其它相关文章!

相关文章

  • JS中的二叉树遍历详解

    JS中的二叉树遍历详解

    这篇文章主要为大家详细介绍了JS中的二叉树遍历,何为二叉树,什么是二叉树的遍历,感兴趣的小伙伴们可以参考一下
    2016-03-03
  • 详解JS如何进行变量解构

    详解JS如何进行变量解构

    JavaScript中,可以使用解构赋值的方式来对数组或者对象进行变量解构,下面小编就来为大家详细介绍一下JavaScript实现数组或者对象解构的方法吧
    2023-11-11
  • JS简单实用的倒计时效果实现代码

    JS简单实用的倒计时效果实现代码

    没有事研究了下倒计时的效果,因此自己练习了一下,需要的朋友可以参考下
    2012-08-08
  • Bootstrap CSS组件之大屏幕展播

    Bootstrap CSS组件之大屏幕展播

    这篇文章主要介为大家详细绍了Bootstrap CSS组件之大屏幕展播的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-12-12
  • JavaScript的ES5实现继承的4种常用方法小结

    JavaScript的ES5实现继承的4种常用方法小结

    继承是面向对象软件技术当中的一个概念,这篇文章主要为大家详细介绍了JavaScript ES5实现继承的4种常用方法,感兴趣的小伙伴可以了解一下
    2024-03-03
  • 利用JS测试目标网站的打开响应速度

    利用JS测试目标网站的打开响应速度

    本文简单说明利用JS来测试目标网站的打开响应速度,方法简单明了大家一看就明白并附上了脚本源码
    2017-12-12
  • javascript[js]获取url参数的代码

    javascript[js]获取url参数的代码

    多浏览器兼容用javascript获取url参数的方法比较推荐的一种
    2007-10-10
  • TypeScript接口介绍

    TypeScript接口介绍

    这篇文章主要介绍了TypeScript接口,接口的作用就是为这些类型命名和为你的代码或第三方代码定义契约。下面我们一起进入文章看看TypeScript接口得具体定义吧,需要的朋友也可以参考一下
    2021-12-12
  • 前端不使用i18n该如何优雅的实现多语言

    前端不使用i18n该如何优雅的实现多语言

    多语言的重要性相信不需要多言,下面这篇文章主要给大家介绍了关于前端不使用i18n该如何优雅的实现多语言,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2023-01-01
  • 将函数的实际参数转换成数组的方法

    将函数的实际参数转换成数组的方法

    实际参数在函数中我们可以使用 arguments 对象获得 (注:形参可通过 arguments.callee 获得),虽然 arguments 对象与数组形似,但仍不是真正意义上的数组。
    2010-01-01

最新评论