How to use Promise.allSettled()? The following article will take you to understand Promise.allSettled() and introduce how to use it. I hope it will be helpful to you!
Promise.allSettled()
The method returns a value when all given promises have been fulfilled
or rejected# The
promise after ## is accompanied by an object array, each object representing the corresponding promise result.
Promise.allSettled() How it works.
1. Promise.allSettled()
Promise.allSettled() can be used to execute independent asynchronous operations in parallel and collect the results of these operations result.
promise (usually an iterable object) as a parameter:
const statusesPromise = Promise.allSettled(promises);When all input
promises are
fulfilled or
rejected,
statusesPromise will resolve to an array with their status
{ status: 'fulfilled', value: value }
— If the corresponding promise has been
fulfilled- or
{status: 'rejected', reason: reason }
If the corresponding promise has been
rejected
then Syntax to extract their status:
statusesPromise.then(statuses => { statuses; // [{ status: '...', value: '...' }, ...] });Or use
async/await Syntax:
const statuses = await statusesPromise; statuses; // [{ status: '...', value: '...' }, ...]
2. Get fruits and vegetables
Before we delve intoPromise.allSettle(), let’s define two simple
helper functions.
resolveTimeout(value, delay) returns a promise, which is implemented with
value after
delay time has passed
function resolveTimeout(value, delay) { return new Promise( resolve => setTimeout(() => resolve(value), delay) ); }Second,
rejectTimeout(reason, delay) - Returns a promise that is rejected after
delay time with
reason.
promise.allsettle().
2.1 All promises fulfilled
We also visit the local grocery store for vegetables and fruits. Accessing each list is an asynchronous operation:const statusesPromise = Promise.allSettled([ resolveTimeout(['potatoes', 'tomatoes'], 1000), resolveTimeout(['oranges', 'apples'], 1000) ]); // wait... const statuses = await statusesPromise; // after 1 second console.log(statuses); // [ // { status: 'fulfilled', value: ['potatoes', 'tomatoes'] }, // { status: 'fulfilled', value: ['oranges', 'apples'] } // ]
Online example: https://codesandbox.io/s/all-resolved-yyc0l?file=/src/index.js
Promise.allSettled([...])Returns a promise
statusesPromise, which is resolved within 1 second, just after the vegetables and fruits are resolved, solved in parallel.
statusesPromise Resolve as an array containing status.
- The first item of the array contains the completed status of the vegetables:
status: 'fulfilled', value: ['potatoes', 'tomatoes'] }
- In the same way, the second item is the completion status of the fruit:
{ status: 'fulfilled', value: ['oranges', 'apples'] }
2.2 A promise is rejected
Imagine that there is no more fruit in the grocery store. In this case, we reject the fruit promise.promise.allsettle() How does it work in this case?
const statusesPromise = Promise.allSettled([ resolveTimeout(['potatoes', 'tomatoes'], 1000), rejectTimeout(new Error('Out of fruits!'), 1000) ]); // wait... const statuses = await statusesPromise; // after 1 second console.log(statuses); // [ // { status: 'fulfilled', value: ['potatoes', 'tomatoes'] }, // { status: 'rejected', reason: Error('Out of fruits!') } // ]
Online example: https://codesandbox.io/s/one -rejected-ij3uo?file=/src/index.js
Promise.allSettled([...]) The returned promise is in
1 seconds Then it is parsed into a status array:
- The first item of the array, vegetables
promise
Successfully parsed:
{ status: 'fulfilled', value: [' potatoes', 'tomatoes'] } ##The second item is a rejection status because the fruit promise was rejected: - { status: 'rejected', reason : Error('Out of fruits') }
will still successfully parse a status array.
What if the grocery store is sold out of vegetables and fruits? In this case, both promises will be rejected.
const statusesPromise = Promise.allSettled([ rejectTimeout(new Error('Out of vegetables!'), 1000), rejectTimeout(new Error('Out of fruits!'), 1000) ]); // wait... const statuses = await statusesPromise; // after 1 second console.log(statuses); // [ // { status: 'rejected', reason: Error('Out of vegetables!') }, // { status: 'rejected', reason: Error('Out of fruits!') } // ]Online example: https://codesandbox.io/s/all-rejected-z4jee?file=/src/index.js
In this case case,statusesPromise
still successfully resolves to a status array. However, the array contains the status of rejected promises.
Promise.allSettled(promises)
You can run promises in parallel and collect the status (fulfilled or reject) into one in an aggregate array.
Effective when you need to perform parallel and independent asynchronous operations and collect all results, even though some asynchronous operations may fail. <blockquote>
<p>English original address: https://dmitripavlutin.com/promise-all-settled/</p>
<p>Author: Dmitri Pavlutin<br></p>
</blockquote>
<p>More programming related For knowledge, please visit: <a href="https://www.php.cn/course.html" target="_blank" textvalue="编程视频">programming video</a>! ! </p>
The above is the detailed content of In-depth analysis of how to use Promise.allSettled(). For more information, please follow other related articles on the PHP Chinese website!

去掉重复并排序的方法:1、使用“Array.from(new Set(arr))”或者“[…new Set(arr)]”语句,去掉数组中的重复元素,返回去重后的新数组;2、利用sort()对去重数组进行排序,语法“去重数组.sort()”。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于Symbol类型、隐藏属性及全局注册表的相关问题,包括了Symbol类型的描述、Symbol不会隐式转字符串等问题,下面一起来看一下,希望对大家有帮助。

怎么制作文字轮播与图片轮播?大家第一想到的是不是利用js,其实利用纯CSS也能实现文字轮播与图片轮播,下面来看看实现方法,希望对大家有所帮助!

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于对象的构造函数和new操作符,构造函数是所有对象的成员方法中,最早被调用的那个,下面一起来看一下吧,希望对大家有帮助。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于面向对象的相关问题,包括了属性描述符、数据描述符、存取描述符等等内容,下面一起来看一下,希望对大家有帮助。

方法:1、利用“点击元素对象.unbind("click");”方法,该方法可以移除被选元素的事件处理程序;2、利用“点击元素对象.off("click");”方法,该方法可以移除通过on()方法添加的事件处理程序。

foreach不是es6的方法。foreach是es3中一个遍历数组的方法,可以调用数组的每个元素,并将元素传给回调函数进行处理,语法“array.forEach(function(当前元素,索引,数组){...})”;该方法不处理空数组。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于BOM操作的相关问题,包括了window对象的常见事件、JavaScript执行机制等等相关内容,下面一起来看一下,希望对大家有帮助。


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

Notepad++7.3.1
Easy-to-use and free code editor

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

Dreamweaver CS6
Visual web development tools

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment
