在前端开发中,我们经常需要同时发起多个请求并等待它们全部完成后再进行下一步操作。ES7 中的 Promise.allSettled 方法可以帮助我们实现并行执行多个请求的功能。
Promise.allSettled 方法简介
Promise.allSettled 方法接收一个 Promise 数组作为参数,并返回一个新的 Promise 对象。这个新的 Promise 对象在所有传入的 Promise 对象都已经 settled(即 fulfilled 或 rejected)后才会 settled。返回的 Promise 对象的值是一个数组,其中每个元素都是一个对象,表示对应的 Promise 对象的状态和结果。
Promise.allSettled 方法与 Promise.all 方法的不同之处在于,Promise.all 方法在任何一个传入的 Promise 对象 rejected 后就会立即 rejected,并返回该 Promise 对象的错误信息。而 Promise.allSettled 方法会等待所有传入的 Promise 对象 settled 后才会 settled,并返回所有 Promise 对象的状态和结果。
代码示例
以下是一个使用 Promise.allSettled 方法并行执行多个请求的示例代码:
-- -------------------- ---- ------- ----- -------- - - -------------------- -------------------- ------------------- -- ---------------------------- ------------- -- - ---------------------- -- - -- -------------- --- ------------ - -------------------------- - ---- - ----------------------------- - --- -- ------------ -- - --------------------- ---
在这个示例中,我们创建了一个包含三个 fetch 请求的 Promise 数组。然后,我们调用 Promise.allSettled 方法并传入这个 Promise 数组作为参数。在 Promise.allSettled 方法返回的 Promise 对象 settled 后,我们遍历结果数组,并根据每个元素的状态输出对应的结果或错误信息。
深入解析
Promise.allSettled 方法的返回值是一个 Promise 对象,该对象的状态和值取决于传入的 Promise 数组的状态和值。如果传入的所有 Promise 对象都 fulfilled,那么返回的 Promise 对象的状态就是 fulfilled,值是一个数组,其中每个元素都是一个对象,表示对应的 Promise 对象的状态和结果。如果传入的任何一个 Promise 对象 rejected,那么返回的 Promise 对象的状态就是 rejected,值是一个包含错误信息的对象。
以下是一个更复杂的示例,通过 Promise.allSettled 方法并行执行多个请求并处理结果:
-- -------------------- ---- ------- ----- ---- - - ----------------------------------------------- ----------------------------------------------- ------------------------------------------------- -- ----- -------- - ------------ -- ------------ ---------------------------- ------------- -- - ----- ---------------- - --------------------- -- ------------- --- ------------- ----- --------------- - --------------------- -- ------------- --- ------------ ---------------------- ----------- ------------------------------- -- - -------------------------- --- --------------------- ----------- ------------------------------ -- - ----------------------------- --- -- ------------ -- - --------------------- ---
在这个示例中,我们首先定义了一个包含三个 URL 的数组。然后,我们使用数组的 map 方法将每个 URL 转换为一个 fetch 请求,并将所有请求的 Promise 对象存储在一个数组中。接下来,我们调用 Promise.allSettled 方法并传入这个 Promise 数组作为参数。在 Promise.allSettled 方法返回的 Promise 对象 settled 后,我们使用 filter 方法分别筛选出 fulfilled 和 rejected 的结果,并分别输出它们的值或错误信息。
总结
使用 Promise.allSettled 方法可以方便地实现并行执行多个请求的功能,并且可以处理所有请求的状态和结果。在实际开发中,我们可以根据需要使用 Promise.allSettled 方法来简化代码并提高效率。
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/650527a795b1f8cacd1ad5bf