离开A页面时,取消A页面的axios接口数据请求

需求:从A页面跳转至B页面时,要取消A页面的axios请求;有时候,我们可能需要在发送请求后取消它,比如用户在请求还未完成时离开了当前页面或者执行了其他操作,本文将介绍如何在使用 Axios 发送请求时取消这些请求。

Axios 提供了 CancelToken 类来创建取消标记。该类中有个source()方法。取消标记实际上是一个包含 cancel 方法的对象。代码如下;

import axios from 'axios';

// 创建取消标记
const source = axios.CancelToken.source();

// 发送请求并关联取消标记

axios.get('/api/data', {
  cancelToken: source.token
});

然后,在Vue Router的导航守卫中,监听路由变化,在离开页面时取消之前的请求:

import axios from 'axios';

router.beforeEach((to, from, next) => {
  source.cancel('路由跳转,取消请求');
  next();
});

 也可以在vue组件的beforeDestory()钩子中或者destory()去取消请求:

destroyed () {
    //window.removeEventListener('resize', this.screenAdapter)
    //this.$socket.unRegisterCallBack('hotData')  
    // 取消请求
   source.cancel('请求取消的原因');
  },

综上所述:主要是利用axios 所提供的cancelToken.source()去创建取消标记即

const source = axios.CancelToken.source();

然后在发送请求时去关联标记,即cancelToken: source.token;

最后在合适的时机用source.cancel()去取消请求

相关推荐

  1. 离开A页面取消A页面axios接口数据请求

    2024-04-26 10:24:03       15 阅读
  2. 用户在页面离开发送http请求,如何成功

    2024-04-26 10:24:03       30 阅读
  3. Vue路由切换 & Axios接口取消重复请求

    2024-04-26 10:24:03       22 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-26 10:24:03       19 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-26 10:24:03       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-26 10:24:03       20 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-26 10:24:03       20 阅读

热门阅读

  1. Python和C++音调音符规划和算法

    2024-04-26 10:24:03       32 阅读
  2. 力扣795.区间子数组个数 | 树状数组解法

    2024-04-26 10:24:03       13 阅读
  3. 磨损对输送带安全的影响

    2024-04-26 10:24:03       33 阅读
  4. C#中的LINQ(Language-Integrated Query)

    2024-04-26 10:24:03       14 阅读
  5. 二叉树层次遍历

    2024-04-26 10:24:03       19 阅读
  6. 分布式与微服务区别?

    2024-04-26 10:24:03       11 阅读
  7. npm cnpm pnpm yarn 有什么区别? 哪个更好用呢?

    2024-04-26 10:24:03       15 阅读
  8. sklearn混淆矩阵的计算和seaborn可视化

    2024-04-26 10:24:03       19 阅读
  9. springboot+Vue实现分页

    2024-04-26 10:24:03       13 阅读
  10. 相交链表的判断(leetcode)

    2024-04-26 10:24:03       11 阅读