为了账号安全,请及时绑定邮箱和手机立即绑定

在线等,挺急的!axios.all 多个请求同时报错 catch不到各位有什么建议?

在线等,挺急的!axios.all 多个请求同时报错 catch不到各位有什么建议?

慕娘9325324 2019-10-25 21:03:09
catch不到多个报错信息两个请求都返回了报错状态axios.all([this.getFormData(),this.getFormHead()]).then(axios.spread((fromDataResp,formHeadResp)=>{console.log("成功")})).catch(error=>{console.log(error,'只能打印第二条报错')})试过这样也不行axios.all([this.getFormData(),this.getFormHead()]).then(axios.spread((fromDataResp,formHeadResp)=>{console.log("成功")})).catch(axios.spread((fromDataerr,formHeaderr)=>{console.log(fromDataerr)//underfindconsole.log(formHeaderr)//underfind}))有大佬能指点一下吗???
查看完整描述

2 回答

?
忽然笑

TA贡献1806条经验 获得超5个赞

使用Promise.all只catch每一个函数。结果统一处理
;!asyncfunction(){
letres=awaitPromise.all([
fun01().catch(err=>err),
fun02().catch(err=>err),
fun03().catch(err=>err),
])
console.log('res',res);//["成功:11111","失败:22222","成功:33333"]
functionfun01(){
returnnewPromise((resolve,reject)=>{
setTimeout(()=>{
resolve('成功:11111')
},2000)
})
}
functionfun02(){
returnnewPromise((resolve,reject)=>{
setTimeout(()=>{
reject('失败:22222')
},2000)
})
}
functionfun03(){
returnnewPromise((resolve,reject)=>{
setTimeout(()=>{
resolve('成功:33333')
},2000)
})
}
}();
                            
查看完整回答
反对 回复 2019-10-25
  • 2 回答
  • 0 关注
  • 1113 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信