promise.all和promise.race途中出现错误运行情况
1.promise.all
a.在使用时,如果中间不出错返回reject,会在.then()后返回每一个promise的resolve()返回的内容。
function p1() {
return new Promise((resolve,reject)=>{
console.log('成功1')
resolve('成功1')
})
}
function p2() {
return new Promise((resolve,reject)=>{
console.log('成功2')
resolve('成功2')
// reject('失败原因')
})
}
function p3() {
return new Promise((resolve,reject)=>{
console.log('成功3')
resolve('成功3')
})
}
Promise.all([p1(),p2(),p3()]).then((res)=>{
console.log(res,"res")
}).catch((err)=>{
console.log(err,"err")
})
打印结果为:

b.在使用时,如果有一项出现错误返回reject,会直接走catch,取到reject返回的错误信息,但不影响之后的promise,其他的promise会正常执行,只是结果拿不到。
function p1() {
return new Promise((resolve,reject)=>{
console.log('成功1')
resolve('成功1')
})
}
function p2() {
return new Promise((resolve,reject)=>{
// console.log('成功2')
// resolve('成功2')
reject('失败原因')
})
}
function p3() {
return new Promise((resolve,reject)=>{
console.log('成功3')
resolve('成功3')
})
}
Promise.all([p1(),p2(),p3()]).then((res)=>{
console.log(res,"res")
}).catch((err)=>{
console.log(err,"err")
})
打印的结果为:

总结:1.Promise.all 里面参数为一个数组,数组的每一项是一个返回promise 的函数调用;
2.then 的第一个参数是所有promise都成功的调用,返回结果是一个数组,数组的每一项为函数promise 的返回结果;
3.执行期间有一个返回rejcet则执行失败回调,拿到的是第一个失败得值,其他promise进程不受影响;
2.promise.race(只看谁先完成返回谁)
如果全部是正常resolve,看谁快返回的.then(res)结果值是谁
function p1() {
return new Promise((resolve,reject)=>{
console.log('成功1')
resolve('成功1')
})
}
function p2() {
return new Promise((resolve,reject)=>{
console.log('成功2')
resolve('成功2')
// reject('失败原因')
})
}
function p3() {
return new Promise((resolve,reject)=>{
console.log('成功3')
resolve('成功3')
})
}
Promise.race([p1(),p2(),p3()]).then((res)=>{
console.log(res,"res")
}).catch((err)=>{
console.log(err,"err")
})
打印结果为:

如果第一个就出现错误返回reject,则走错误回调,返回错误的值
function p1() {
return new Promise((resolve,reject)=>{
console.log('成功1')
resolve('成功1')
})
}
function p2() {
return new Promise((resolve,reject)=>{
// console.log('成功2')
// resolve('成功2')
reject('失败原因')
})
}
function p3() {
return new Promise((resolve,reject)=>{
console.log('成功3')
resolve('成功3')
})
}
//注意p1,p2位置
Promise.race([p2(),p1(),p3()]).then((res)=>{
console.log(res,"res")
}).catch((err)=>{
console.log(err,"err")
})
打印结果为:


浙公网安备 33010602011771号