Promise.allSettled()方法的语法是什么?

简介: Promise.allSettled()方法的语法是什么?
  1. 基本语法格式
    • Promise.allSettled(iterable)Promise.allSettled()方法的基本语法。其中,iterable是一个可迭代对象,通常是一个包含Promise对象的数组,不过也可以是其他符合可迭代协议的对象,如Set等。
    • 例如:
      const promises = [
        new Promise((resolve) => setTimeout(() => resolve('成功1'), 1000)),
        new Promise((resolve, reject) => setTimeout(() => reject('失败2'), 1500)),
        new Promise((resolve) => setTimeout(() => resolve('成功3'), 2000))
      ];
      Promise.allSettled(promises)
      .then((results) => {
             
          console.log(results);
        });
      
  2. 返回值
    • 它返回一个新的Promise。这个Promise会在所有传入iterable中的Promise对象都已完成(fulfilled或者rejected)后被resolved
    • 返回的结果是一个数组,数组中的每个元素是一个对象,这个对象有两个属性:
      • status:其值为"fulfilled"或者"rejected",用于表示对应的Promise是成功还是失败。
      • status"fulfilled"时,对象有value属性,其值为对应的Promise成功返回的值;当status"rejected"时,对象有reason属性,其值为对应的Promise被拒绝的原因。例如:
        [
        {
                 status: "fulfilled", value: "成功1"},
        {
                 status: "rejected", reason: "失败2"},
        {
                 status: "fulfilled", value: "成功3"}
        ]
        
  3. 错误处理
    • Promise.all()不同,Promise.allSettled()不会因为其中一个Promiserejected就立即返回一个rejectedPromise。它会等待所有的Promise完成后,将所有结果(包括成功和失败)都放在返回的数组中。
    • 如果在执行Promise.allSettled()过程中出现了同步错误(例如,传递给Promise.allSettled()的参数不是可迭代对象),那么它会抛出一个同步错误,就像其他JavaScript函数一样。但如果是内部的Promise对象在异步执行过程中出现错误,这些错误会被捕获并作为rejected的结果包含在最终返回的数组中。
目录
相关文章
|
6月前
|
前端开发
在什么场景下适合使用 Promise.race() 方法?
在什么场景下适合使用 Promise.race() 方法?
352 68
|
6月前
|
前端开发
如何使用 Promise 的 all 方法?
如何使用 Promise 的 all 方法?
613 63
|
6月前
|
前端开发
如何使用 Promise 的 race 方法?
如何使用 Promise 的 race 方法?
361 62
|
存储 前端开发
除了 Promise.all(),还有哪些方法可以处理异步并发操作?
在上述示例中,`concurrentPromises` 函数接受一个Promise数组和最大并发数作为参数,通过手动控制并发执行的Promise数量,实现了对异步操作的并发控制,并在所有Promise完成后返回结果数组。
|
前端开发 索引
Promise.all() 方法的参数可以是什么类型?
综上所述,`Promise.all()` 方法的参数类型较为灵活,但无论使用哪种类型的可迭代对象作为参数,其核心的异步操作处理逻辑和成功失败的判断机制都是一致的,都是为了方便地处理多个异步操作的并发执行和结果汇总。
|
9月前
|
前端开发
在Promise链中,如果前面的catch方法没有捕获到错误,后面的catch方法还会执行吗?
在Promise链中,如果前面的catch方法没有捕获到错误,后面的catch方法还会执行吗?
261 58
|
9月前
|
前端开发
在Promise链中是否可以多次使用catch方法?
在Promise链中是否可以多次使用catch方法?
241 58
|
9月前
|
前端开发
Promise有哪些常用的方法?
Promise有哪些常用的方法?
240 58
|
9月前
|
前端开发
如何在不使用catch方法的情况下处理Promise.reject()抛出的错误?
如何在不使用catch方法的情况下处理Promise.reject()抛出的错误?
354 57
|
10月前
|
前端开发 JavaScript
除了使用Polyfill,还有其他解决Promise.allSettled()兼容性问题的方法吗?
除了使用Polyfill,还有其他解决Promise.allSettled()兼容性问题的方法吗?
281 81