离开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()去取消请求

相关推荐
Hello--_--World8 小时前
ES15:Object.groupBy() 和 Map.groupBy()、Promise.withResolvers() 相关知识点
开发语言·前端·javascript
Cache技术分享9 小时前
386. Java IO API - 监控目录变化
前端·后端
Hooray9 小时前
管理后台框架 AI 时代的版本答案,Fantastic-admin 6.0 它来了!
前端·前端框架·ai编程
2501_913680009 小时前
Vue3项目快速接入AI助手的终极方案 - 让你的应用智能升级
前端·vue.js·人工智能·ai·vue·开源软件
开开心心_Every9 小时前
动图制作工具,拆分转视频动态照离线免费
运维·前端·人工智能·edge·pdf·散列表·启发式算法
饭后一颗花生米9 小时前
2026 前端实战:AI 驱动下的性能优化与工程化升级
前端·人工智能·性能优化
YJlio9 小时前
4月14日热点新闻解读:从金融数据到平台治理,一文看懂今天最值得关注的6个信号
java·前端·人工智能·金融·eclipse·电脑·eixv3
xjf77119 小时前
AI重构前端项目指南
前端·ai·重构·编程
踩着两条虫9 小时前
VTJ:应用场景展示
前端·vue.js·架构
恋恋风尘hhh9 小时前
Web 前端安全机制分析:以 Webpack 打包混淆为例
前端·安全·webpack