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

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

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

javascript 复制代码
import axios from 'axios';

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

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

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

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

javascript 复制代码
import axios from 'axios';

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

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

javascript 复制代码
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 天前
Vue3 中虚拟滚动与分页加载的实现原理与实践
前端·性能优化
GIS之路1 天前
GDAL 实现矢量合并
前端
hxjhnct1 天前
React useContext的缺陷
前端·react.js·前端框架
前端 贾公子1 天前
从入门到实践:前端 Monorepo 工程化实战(4)
前端
菩提小狗1 天前
Sqlmap双击运行脚本,双击直接打开。
前端·笔记·安全·web安全
前端工作日常1 天前
我学习到的AG-UI的概念
前端
韩师傅1 天前
前端开发消亡史:AI也无法掩盖没有设计创造力的真相
前端·人工智能·后端
XiaoYu20021 天前
第12章 支付宝SDK
前端
双向331 天前
RAG的下一站:检索增强生成如何重塑企业知识中枢?
前端
拖拉斯旋风1 天前
从零开始:使用 Ollama 在本地部署开源大模型并集成到 React 应用
前端·javascript·ollama