Vue路由切换 & Axios接口取消重复请求

在日常前端开发中, 经常会遇到频繁发起的重复请求, 会给服务器及网络造成不必要的压力, 可通过取消重复请求解决

场景

订单数据条件筛选查询

表单提交按钮频繁点击

路由页面切换请求未取消

解决方案:

在每个请求发起的时候存储当前存储的标记在一个数组或Map中, 针对每个请求(或者特定的请求,可以通过在请求头中加字段)的时候在请求拦截中查询是否重复, 如果已重复则取消历史中重复的请求, 再发起当前请求, 如果没有重复, 则添加存储标记并正常请求, 已请求完成的清除存储标记。

axios中如何取消请求

1、可以使用 CancelToken.source 工厂方法创建 cancel token,像这样:

javascript 复制代码
const CancelToken = axios.CancelToken;
const source = CancelToken.source();
 
axios.get('/user/12345', {
  cancelToken: source.token
}).catch(function(thrown) {
  if (axios.isCancel(thrown)) {
    console.log('Request canceled', thrown.message);
  } else {
     // 处理错误
  }
});
 
axios.post('/user/12345', {
  name: 'new name'
}, {
  cancelToken: source.token
})
 
// 取消请求(message 参数是可选的)
source.cancel('Operation canceled by the user.');

还可以通过传递一个 executor 函数到 CancelToken 的构造函数来创建 cancel token:

javascript 复制代码
const CancelToken = axios.CancelToken;
let cancel;
 
axios.get('/user/12345', {
  cancelToken: new CancelToken(function executor(c) {
    // executor 函数接收一个 cancel 函数作为参数
    cancel = c;
  })
});
 
// cancel the request
cancel();

项目中封装使用。

javascript 复制代码
const pendingXHRMap = new Map();

/**
 * 添加请求
 * @param {Object} config
 */
export const addPendingXHR = (config) => {
  const url = [
    config.method,
    config.url
  ].join("&");
  config.cancelToken = config.cancelToken || new axios.CancelToken(cancel => {
    if (!pendingXHRMap.has(url)) { // 如果 pending 中不存在当前请求,则添加进去
      pendingXHRMap .set(url, cancel);
    }
  });
};

// 删除请求记录
/**
 * 移除请求
 * @param {Object} config;
 */
export const removePendingXHR = (config) => {
  const url = [
    config.method,
    config.url
  ].join("&");
  if (pendingXHRMap.has(url)) { // 如果在 pending 中存在当前请求标识,需要取消当前 请求,并且移除
    const cancel = pendingXHRMap.get(url);
    cancel(url);
    pendingXHRMap .delete(url);
  }
};

axios中使用:

javascript 复制代码
// 请求拦截处理
axios.interceptors.request.use(config => {
    // 这里根据自定义的请求头进行判断
    removePendingXHR(config)
    addPendingXHR(config)
    ...
    return config
})
 
// 响应拦截处理
axios.interceptors.response.use(response => {
    removePendingXHR(response)
    ...
}, error => {
})

Vue中当路由切换页面的时候,将上一个页面的所有请求取消。

javascript 复制代码
router.beforeEach((to, from, next) => {
    // 遍历pendingMap,将上一个页面的所有请求cancel掉
    pendingXHRMap.forEach((cancel) => {
        cancel();
    });
    pendingXHRMap.clear()
})
相关推荐
五月君_16 分钟前
炸裂!Claude Opus 4.6 与 GPT-5.3 同日发布:前端人的“自动驾驶“时刻到了?
前端·gpt
Mr Xu_20 分钟前
前端开发中CSS代码的优化与复用:从公共样式提取到CSS变量的最佳实践
前端·css
低代码布道师42 分钟前
Next.js 16 全栈实战(一):从零打造“教培管家”系统——环境与脚手架搭建
开发语言·javascript·ecmascript
鹏北海-RemHusband1 小时前
从零到一:基于 micro-app 的企业级微前端模板完整实现指南
前端·微服务·架构
LYFlied1 小时前
AI大时代下前端跨端解决方案的现状与演进路径
前端·人工智能
光影少年1 小时前
AI 前端 / 高级前端
前端·人工智能·状态模式
一位搞嵌入式的 genius1 小时前
深入 JavaScript 函数式编程:从基础到实战(含面试题解析)
前端·javascript·函数式
anOnion1 小时前
构建无障碍组件之Alert Dialog Pattern
前端·html·交互设计
choke2331 小时前
[特殊字符] Python 文件与路径操作
java·前端·javascript
云飞云共享云桌面1 小时前
高性能图形工作站的资源如何共享给10个SolidWorks研发设计用
linux·运维·服务器·前端·网络·数据库·人工智能