axios封装 防止重复请求

// 正在进行中的请求列表
let reqList = []

/**
 * 阻止重复请求
 * @param {array} reqList - 请求缓存列表
 * @param {string} url - 当前请求地址
 * @param {function} cancel - 请求中断函数
 * @param {string} errorMessage - 请求中断时需要显示的错误信息
 */
const stopRepeatRequest = function (reqList, url, cancel, errorMessage) {
   
  const errorMsg = errorMessage || ''
  for (let i = 0; i < reqList.length; i++) {
   
    if (reqList[i] === url) {
   
      
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用axios进行请求时,可以通过封装来实现取消重复请求的功能。以下是一个简单的封装示例: ```javascript import axios from 'axios'; // 创建一个取消请求的CancelToken实例 const cancelToken = axios.CancelToken; const source = cancelToken.source(); // 定义一个变量用于存储重复请求的标识 let pendingRequest = null; // 创建一个axios实例 const instance = axios.create({ baseURL: 'http://api.example.com', timeout: 5000, }); // 请求拦截器 instance.interceptors.request.use(config => { // 如果存在重复请求,则取消之前的请求 if (pendingRequest) { pendingRequest.cancel('canceled due to duplicate request'); } // 存储当前请求 pendingRequest = source; // 将取消标识添加到请求配置中 config.cancelToken = source.token; return config; }, error => { return Promise.reject(error); }); // 响应拦截器 instance.interceptors.response.use(response => { // 请求完成后,将标识置为null pendingRequest = null; return response.data; }, error => { // 请求出错后,将标识置为null pendingRequest = null; return Promise.reject(error); }); export default instance; ``` 在上述示例中,我们通过创建一个取消请求的CancelToken实例和一个变量pendingRequest来管理重复请求。在请求拦截器中,如果存在重复请求,就取消之前的请求并将当前请求存储到pendingRequest变量中。在响应拦截器中,无论请求成功还是失败,都将pendingRequest标识重置为null。 这样,当多次快速发起相同的请求时,只会保留最后一次的请求,之前的请求都会被取消。这样就实现了取消重复请求的功能。 请注意,这只是一个简单的示例,实际应用中可能需要根据具体场景进行适当的修改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值