同一个接口,掉n次,取消上次请求

关于在同一个接口连续调用两次时,取消上一次的请求。这通常是为了防止重复请求导致的数据不一致或性能问题。首先,我需要查看用户提供的代码文件,找到处理请求的部分,通常是axios的配置。

在用户提供的request.js中,主要使用axios创建了一个service实例,并配置了请求和响应拦截器。为了实现取消请求的功能,我需要引入axios的CancelToken。每次发起请求时,生成一个唯一的cancel token,并将前一个请求的cancel函数保存起来,以便在下次请求时取消之前的。

接下来,我需要确定在何处存储cancel函数。可以使用一个Map对象来保存每个接口的cancel函数,这样不同的接口之间不会互相干扰。当发起新的请求时,检查Map中是否存在该接口的pending请求,如果存在,则调用cancel方法取消,并移除旧的记录。

然后,在请求拦截器中,为每个请求添加cancel token,并将cancel函数存入Map。同时,在响应拦截器中,无论请求成功还是失败,都需要从Map中移除对应的记录,避免内存泄漏。

需要注意的是,用户现有的代码中已经处理了请求的序列化和token的添加,所以修改时不能影响原有功能。另外,要确保取消请求的逻辑不会干扰到其他接口,只针对同一个接口的连续调用。

最后,测试一下修改后的代码是否能在第二次调用时正确取消前一次请求,同时不影响其他正常流程,比如错误处理和响应数据的返回。

在Axios中实现取消重复请求的功能,可以通过CancelToken来处理。以下是修改后的核心代码片段:

javascript 复制代码
request.js
Apply
// 创建axios实例
const service = axios.create({
  // ... 原有配置 ...
})

// 存储pending请求的Map
const pendingRequests = new Map();

// request拦截器
service.interceptors.request.use(config => {
  // 生成唯一标识
  const requestKey = `${config.method}-${config.url}`;
  
  // 如果存在重复请求,取消前一个
  if (pendingRequests.has(requestKey)) {
    const cancel = pendingRequests.get(requestKey);
    cancel(requestKey);
    pendingRequests.delete(requestKey);
  }

  // 创建新的CancelToken
  config.cancelToken = new axios.CancelToken(cancel => {
    pendingRequests.set(requestKey, cancel);
  });

  // ... 原有代码(token处理、参数序列化等) ...
  return config
}, error => {
  Promise.reject(error)
})

// 响应拦截器
service.interceptors.response.use(res => {
  // 请求完成时移除pending记录
  const requestKey = `${res.config.method}-${res.config.url}`;
  pendingRequests.delete(requestKey);
  
  // ... 原有响应处理代码 ...
}, error => {
  // 如果是主动取消的请求,不报错
  if (axios.isCancel(error)) {
    console.log('Request canceled:', error.message);
    return Promise.reject({ type: 'cancel' });
  }
  
  // ... 原有错误处理代码 ...
})

主要修改点:

  1. 新增pendingRequests用于存储进行中的请求
  2. 在请求拦截器中添加取消逻辑,使用「请求方法+URL」作为唯一标识
  3. 在响应拦截器中清除已完成请求的记录
  4. 对取消的请求进行特殊处理,避免触发错误提示

该实现会针对同一个接口的重复请求(相同method和URL),自动取消前一次未完成的请求。最后一次请求会被正常发送,之前的相同请求会被取消。

相关推荐
SUPER52662 小时前
FastApi项目启动失败 got an unexpected keyword argument ‘loop_factory‘
java·服务器·前端
sanx182 小时前
专业电竞体育数据与系统解决方案
前端·数据库·apache·数据库开发·时序数据库
你的人类朋友4 小时前
【Node】认识一下Node.js 中的 VM 模块
前端·后端·node.js
Cosolar4 小时前
FunASR 前端语音识别代码解析
前端·面试·github
@大迁世界7 小时前
Vue 设计模式 实战指南
前端·javascript·vue.js·设计模式·ecmascript
芭拉拉小魔仙7 小时前
Vue项目中如何实现表格选中数据的 Excel 导出
前端·vue.js·excel
jump_jump7 小时前
妙用 localeCompare 获取汉字拼音首字母
前端·javascript·浏览器
U.2 SSD7 小时前
Echarts单轴坐标系散点图
前端·javascript·echarts
德育处主任Pro8 小时前
前端玩转大模型,DeepSeek-R1 蒸馏 Llama 模型的 Bedrock 部署
前端·llama
Jedi Hongbin8 小时前
Three.js NodeMaterial 节点材质系统文档
前端·javascript·three.js·nodematerial