Promise.all方法,Promise.race方法以及使用
时间: 2023-10-20 17:02:44 浏览: 48
Promise.all 方法接收一个 Promise 数组作为参数,并且返回一个新的 Promise 对象。该新的 Promise 对象在所有 Promise 对象都变为 resolved 状态时才会被 resolved,或者在任意一个 Promise 对象变为 rejected 状态时被 rejected。返回的 Promise 对象的结果将是一个包含所有 Promise 对象结果的数组,其顺序与传入的 Promise 数组顺序一致。
以下是一个使用 Promise.all 方法的示例:
```javascript
const promise1 = new Promise((resolve, reject) => {
setTimeout(() => {
resolve('Promise 1 resolved');
}, 1000);
});
const promise2 = new Promise((resolve, reject) => {
setTimeout(() => {
resolve('Promise 2 resolved');
}, 2000);
});
const promise3 = new Promise((resolve, reject) => {
setTimeout(() => {
resolve('Promise 3 resolved');
}, 1500);
});
Promise.all([promise1, promise2, promise3])
.then(results => {
console.log(results); // ['Promise 1 resolved', 'Promise 2 resolved', 'Promise 3 resolved']
})
.catch(error => {
console.log(error);
});
```
Promise.race 方法也接收一个 Promise 数组作为参数,并且返回一个新的 Promise 对象。该新的 Promise 对象将与最先完成(无论是 resolved 或 rejected)的 Promise 对象具有相同的状态。
以下是一个使用 Promise.race 方法的示例:
```javascript
const promise1 = new Promise((resolve, reject) => {
setTimeout(() => {
resolve('Promise 1 resolved');
}, 1000);
});
const promise2 = new Promise((resolve, reject) => {
setTimeout(() => {
resolve('Promise 2 resolved');
}, 2000);
});
const promise3 = new Promise((resolve, reject) => {
setTimeout(() => {
reject('Promise 3 rejected');
}, 1500);
});
Promise.race([promise1, promise2, promise3])
.then(result => {
console.log(result); // 'Promise 1 resolved'
})
.catch(error => {
console.log(error); // 'Promise 3 rejected'
});
```
使用 Promise.all 方法和 Promise.race 方法可以更方便地处理多个 Promise 对象的状态和结果。