取消axios请求的正确姿势

bug

直接使用sourcetokencancel请求,会导致这样的问题:所有的请求都被cancel掉了!这很明显不符合我们的要求:跳转路由的时候清除掉上一个页面的请求,当前页面的请求应保留。

解决办法

在拦截器中为每一个请求new一个token,然后存在store里面。在路由钩子中调用相应的cancel方法就好了。

  interceptors (instance) {
    instance.interceptors.request.use(config => {
      config.cancelToken = new axios.CancelToken(cancel => {
        store.dispatch('status/saveRequestQueue', cancel)
      })
      return config
    }, error => {
      this.errorHandler('请求失败 ' + error.toString())
    })
  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值