ES6之Promise的静态方法
为什么要有静态方法,主要是为了对多个 Promise 进行更好的控制。
Promise.resove() ,Promise.reject() 可以返回一个成功和失败的 Promise 。
Promise.all() 只有全部成功才会成功,返回的是失败的数组
Promise.any()有一个成功就算成功,返回的是成功的数组
Promise.allSettled() 全部已决就算成功,不会失败
Promise.race() 最先已决的状态,可能成功,可能失败
如果想解决多个异步任务,可以像下面这个例子:
// 做饭
function cook() {
return new Promise((resolve, reject) => {
console.log('邓哥打开了电饭煲');
setTimeout(() => {
if (Math.random() < 0.5) {
resolve('饭已ok');
} else {
reject('做饭却忘了加水,米饭变成了爆米花');
}
}, 2000);
});
}
// 洗衣服
function wash() {
return new Promise((resolve, reject) => {
console.log('邓哥打开了洗衣机');
setTimeout(() => {
if (Math.random() < 0.5) {
resolve('衣服已经洗好');
} else {
reject('洗衣服时停水了,洗了个寂寞');
}
}, 2500);
});
}
// 打扫卫生
function sweep() {
return new Promise((resolve, reject) => {
console.log('邓哥打开了扫地机器人');
setTimeout(() => {
if (Math.random() < 0.5) {
resolve('地板扫的非常干净');
} else {
reject('扫地机器人被哈士奇一爪掀翻了');
}
}, 3000);
});
}
Promise.allSettled([cook(), wash(), sweep()]).then((result) => {
// 处理汇总结果
const report = result
.map((r) => (r.status === 'fulfilled' ? r.value : r.reason))
.join(';');
console.log(report);
});