Promise.all()错误处理

为了让一个fetch宕机之后,promise.all的then里面还能拿到数据,重点就是给每个fetch的promise对象增加容错处理
这样promise.all可以分别处理error问题

getLatestJob(context){
      const result1=api.getJobJsonFromShield(context)
        .then(response => {
          context.state.isShieldFetch=false
          return response.json();
        })
        .catch(function(err) {
          context.state.isShieldFetch=true
          return [];
        });
      const result2=api.getJobJson(context)
        .then(response => {
          context.state.isNBUFetch=false
          return response.json();
        })
        .catch(function(err) {
          context.state.isNBUFetch=true
          return [];
        });

      Promise.all([result1, result2])
        .then(([shieldData, nbuData])=>{
          context.commit('mergeList',{"shield":shieldData,"nbuData":nbuData})

        });
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`Promise.all` 是一个非常有用的方法,它可以同时处理多个 Promise 对象,并在所有 Promise 都 resolved 后返回一个新的 Promise 对象。然而,有一些坑需要注意: 1. **一旦有一个 Promise rejected,Promise.all 就会立即停止并返回一个 rejected Promise**:如果其中一个 Promise 被 rejected,Promise.all 将立即停止执行并返回一个 rejected Promise。这意味着,即使其他的 Promise 已经 resolved,它们的结果也将被忽略。因此,在使用 Promise.all 时,请确保你对每个 Promise 都进行了适当的错误处理。 2. **Promise.all 返回顺序与输入顺序一致**:Promise.all 返回的结果数组将按照输入数组中的顺序排列。这意味着,如果你传入的 Promise 数组的顺序很重要,那么你可以根据返回的结果数组来获取对应的结果。 3. **如果传入的不是 Promise 对象,Promise.all 会自动将其转换为 resolved 状态**:当你传入的数组中包含非 Promise 对象时,Promise.all 会自动将它们转换为 resolved 状态,并将它们的值作为结果数组中的对应值。这可能会导致一些意外行为,因此在使用 Promise.all 时,请确保你传入的是合适的 Promise 对象。 4. **记得处理 Promise.all 返回的 Promise**:因为 Promise.all 返回一个新的 Promise 对象,所以你需要使用 `.then()` 或 `.catch()` 来处理它的结果或错误。如果你忘记处理它,可能会导致未捕获的 Promise rejection 错误。 希望这些信息对你有帮助!如果你有更多关于 Promise.all 的问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值