手写all、race、any
class _Promise {
static race (promiseArr) {
return new Promise((resolve, reject) => {
promiseArr.then((p) => {
Promise.resolve(p).then((res) => {
resolve(res)
}).catch((e) => {
reject(e)
})
})
})
}
static all (promiseArr) {
let len = promiseArr.length;
let result = new Array(len);
let count=0;
return new Promise((resolve, reject) => {
promiseArr.forEach(p => {
Promise.resolve(p).then((res)=> {
result[i] = res
if (++count === len) {
resolve(res)
}
}).catch((e) => {
reject(e)
})
});
})
}
static any (promiseArr) {
let len = promiseArr.length;
let count=0;
return new Promise((resolve, reject) => {
promiseArr.forEach(p => {
Promise.resolve(p).then((res)=> {
resolve(res)
}).catch((e) => {
if (++count === len) {
reject(e)
}
})
});
})
}
}
本文详细介绍了JavaScript中的Promise类的三个静态方法:race()用于返回第一个完成的Promise,all()等待所有Promise完成并返回一个数组,any()则在任一Promise完成时返回结果。这些方法有助于处理异步操作的并发控制。
1230

被折叠的 条评论
为什么被折叠?



