手写promise.all
时间: 2023-10-21 20:28:40 浏览: 103
在给定的代码中,实现了一个自定义的promiseAll函数,用于同时处理多个Promise对象。它接受一个Promise对象数组作为参数,并返回一个新的Promise对象,该Promise对象将在所有传入的Promise对象都成功解析后才会被解析,否则将被拒绝。
这个自定义的promiseAll函数的实现通过使用Promise构造函数和Promise.prototype.then方法来实现。它使用了一个计数器来跟踪每个Promise对象的解析状态,并使用一个数组来存储每个Promise对象的解析结果。当所有的Promise对象都成功解析时,它将返回一个包含所有解析结果的数组;当其中任何一个Promise对象被拒绝时,它将返回拒绝的原因。
请注意,以上给出的自定义promiseAll函数的实现是正确的,它通过正确地使用Promise构造函数和Promise.prototype.then方法来实现对多个Promise对象的并行处理。然而在给定的代码中,对于Promise对象的拒绝处理并未进行充分的考虑。在删除了3.txt文件后,Promise对象p3应该被拒绝,但该代码并未正确处理这种情况。因此,需要对代码进行修改以正确处理这种情况。
以下是一个修正后的示例代码,其中包含了对Promise对象的拒绝进行正确处理的修改:
```javascript
function promiseAll(promises) {
return new Promise((resolve, reject) => {
let count = 0;
let results = [];
if (promises.length === 0) {
resolve(results);
} else {
promises.forEach((promise, index) => {
promise.then(result => {
results[index = result;
count++;
if (count === promises.length) {
resolve(results);
}
}).catch(error => {
reject(error);
});
});
}
});
}
let p1 = isReadFile('1.txt');
let p2 = isReadFile('2.txt');
let p3 = isReadFile('3.txt');
promiseAll([p1, p2, p3]).then(res => {
console.log(res);
}).catch(err => {
console.log(err);
});
```
这样修改后的代码将正确处理每个Promise对象的解析结果,无论是成功还是失败。在删除了3.txt文件后,Promise对象p3将被拒绝,并且正确的调用了promiseAll的失败回调函数。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
阅读全文