同一个接口,掉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),自动取消前一次未完成的请求。最后一次请求会被正常发送,之前的相同请求会被取消。

相关推荐
专注API从业者4 小时前
Python + 淘宝 API 开发:自动化采集商品数据的完整流程
大数据·运维·前端·数据挖掘·自动化
烛阴5 小时前
TypeScript高手密技:解密类型断言、非空断言与 `const` 断言
前端·javascript·typescript
样子20186 小时前
Uniapp 之renderjs解决swiper+多个video卡顿问题
前端·javascript·css·uni-app·html
Nicholas686 小时前
flutterAppBar之SystemUiOverlayStyle源码解析(一)
前端
黑客飓风6 小时前
JavaScript 性能优化实战大纲
前端·javascript·性能优化
emojiwoo7 小时前
【前端基础知识系列六】React 项目基本框架及常见文件夹作用总结(图文版)
前端·react.js·前端框架
张人玉8 小时前
XML 序列化与操作详解笔记
xml·前端·笔记
杨荧8 小时前
基于Python的宠物服务管理系统 Python+Django+Vue.js
大数据·前端·vue.js·爬虫·python·信息可视化
YeeWang9 小时前
🎉 Eficy 让你的 Cherry Studio 直接生成可预览的 React 页面
前端·javascript
gnip9 小时前
Jenkins部署前端项目实战方案
前端·javascript·架构