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

相关推荐
yuhaiqiang11 分钟前
为什么这道初中数学题击溃了所有 AI
前端·后端·面试
djk888813 分钟前
支持手机屏幕的layui后台html模板
前端·html·layui
紫_龙15 分钟前
最新版vue3+TypeScript开发入门到实战教程之watch详解
前端·javascript·typescript
默默学前端1 小时前
ES6模板语法与字符串处理详解
前端·ecmascript·es6
lxh01131 小时前
记忆函数 II 题解
前端·javascript
我不吃饼干1 小时前
TypeScript 类型体操练习笔记(三)
前端·typescript
华仔啊1 小时前
除了防抖和节流,还有哪些 JS 性能优化手段?
前端·javascript·vue.js
CHU7290351 小时前
随时随地学新知——线上网课教学小程序前端功能详解
前端·小程序
清粥油条可乐炸鸡1 小时前
motion入门教程
前端·css·react.js
这是个栗子1 小时前
【Vue3项目】电商前台项目(四)
前端·vue.js·pinia·表单校验·面包屑导航