依托 axios 实现全局请求防抖

2023-11-15

更新:该方法已过时(此 API 自 v0.22.0 起已弃用,传送门),新的代替方案是 AbortController ,并且!前端取消请求无法真实取消,原因在于请求发送到服务器后服务器或许已经做了处理,但是前端只是关闭了返回通道,可是实际上服务器已经对该请求做了处理,所以存在风险,不建议在post接口上使用,如需实现同类功能可以让后端同学来。

原文:

最近在看axios的时候发现一个之前用过的功能,但是一直没明白其中原理是什么,但是在仔细阅读了axios的api后结合之前所学,对当下的功能又有了新的理解,故又有了这篇文章。

axios,一个依基于promise的网络请求库。防抖的话这里就不复述了,不懂的可以自己网上查。

请求防抖的实现思路:定义一个数组用来放请求函数,每次在拦截器中判断是否有和数组中地址参数的请求,如果有就取消这个请求并返回。

核心api :axios.CancelToken;
axios的介绍是这样的:

You can also create a cancel token by passing an executor function to the constructor:CancelToken
您还可以通过向构造函数传递执行函数来创建一个取消令牌:CancelToken

简单来说就是用来取消axios的请求方法的。
使用方式:


const CancelToken = axios.CancelToken;
let cancel;

axios.get('/user/12345', {
  cancelToken: new CancelToken(function executor(c) {

    // An executor function receives a cancel function as a parameter
    cancel = c;
  })
});

// cancel the request

cancel();

最后
全局请求防抖具体代码实现:

let cancelToken= axios.CancelToken;//取消api
let pending = []; //声明一个数组用于存储每个ajax请求的取消函数和ajax标识
let removePending = config => {
  pending.find((item,i)=>{
  	//判断当前请求数组中是否存在相同请求地址的接口
  	if(item.u===config.url + "&" + config.method){
     	pending[i].c(); //执行取消方法
	    pending.splice(i, 1); //把这条记录从数组中移除
		return true;
	}
  })
};

//添加请求拦截器
axios.interceptors.request.use(
  config => {
    removePending(config); //在一个ajax发送前执行一下取消操作
    config.cancelToken = new cancelToken(c => {
      // 传入对比参数 和 取消方法
      pending.push({ u: config.url + "&" + config.method, c });
    });
    return config;
  },
  error => {
    return Promise.reject(error);
  }
);

//添加响应拦截器
axios.interceptors.response.use(
  response => {
    //do something
  },
  error => {
   //因为请求被取消了,响应器中会走错误流程,这里返回一下自定义格式
    return {
      data: {
        code: 666,
        cancel: true,
        errorMsg: "请求已关闭"
      }
    };
  }
);

这边还有个优化思路就是在普通项目中还好,碰到带token或者特殊的类似无序参数的请求方法,或者项目特别大的,可能会导致我们的数组的内容长度会特别长,可以尝试在相应中完成请求后删除数组中对应的请求方法,这样的话,我们数组长度就不会越来越长了,但这在小项目中,接口请求不超过四位数,或者没有那种带无序请求参数的话都还是能用的。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

依托 axios 实现全局请求防抖 的相关文章

随机推荐

  • 关于Java锁的面试总结

    面试过程中 也被问过几次关于Java中锁的问题 面试官一般是这么问 你了解Java中的锁吗 有几种 都有什么区别 讲一讲 大致可以分为这几点 锁是什么 有什么用 有哪几种锁 锁的区别 一 锁是什么 有什么用 锁主要用来实现资源共享的同步 只
  • Java实战项目(一)---编写聊天室程序

    刚开始学java 参考 java从入门到精通 这本书 学到网络程序设计基础这一章节 尤其与其他计算机进行通信 觉得还挺有意思的 所有深入地试试做一个小程序 聊天室程序 在代码中加入我自己的理解和困惑 希望能和大家一起探讨 每行的代码基本都有
  • [新人向]MySQL和Navicat下载、安装及使用详细教程

    MySQL和Navicat下载和安装及使用详细教程 因为这些软件的安装很多都是纯英文 作为新手安装真的需要摸索好久 包括我自己 所以Pipi酱就把自己的经验分享给大家 MySQL的安装教程 一 下载安装包链接 1 下载MySQL https
  • 广东电信:故障是外力强加导致 警方介入调查

    昨日下午5时50分开始 广东省内电信网络出现故障 省内多个地区均出现网络宽带无法连接 浏览器无法打开网页等现象 消息发布后 不少外省网友跟帖也表示网络塞车 涉及湖北 湖南 广西 海南和上海等省市区 广东本地不少市民在拨打电信 10000 热
  • 第4章(下)基于前馈神经网络完成鸢尾花分类任务

    文章目录 4 5 实践 基于前馈神经网络完成鸢尾花分类 4 5 1 小批量梯度下降法 4 5 1 1 数据分组 4 5 2 数据处理 4 5 2 2 用DataLoader进行封装 4 5 3 模型构建 4 5 4 完善Runner类 4
  • mac 安装打包工具fastlane

    mark ruby gem工具升级相关 查看gem版本 gem version 查看vgem 版本 ruby vgem version ruby版本管理工具更新 gem update system 查看ruby版本 ruby v 查看rub
  • vue3的provide

    provide 和 inject 通常成对一起使用 使一个祖先组件作为其后代组件的依赖注入方 无论这个组件的层级有多深都可以注入成功 只要他们处于同一条组件链上 provide 提供一个值 可以被后代组件注入 inject 注入一个由祖先组
  • fib

    费氏阵列并不是使用递回来解一定不好 事实上单就执行次数上来说 有一个使用递回的演算法可以更快 big o 是以2为底的Logn值 但是要使用到乘法运算 所以实际上要看所使用的机器而定 Procedure FIB N IF n lt 1 RE
  • redis 击穿、穿透、雪崩

    缓存击穿 单个key在缓存中查询不到 转而去查数据库 如果数据量大 或 并发高 则可能会对数据库造成巨大压力 从而导致数据库崩溃 注意 这里的是 单个key 发生高并发 场景 刚好某个时间点 某单个key缓存过期了 恰好这个时间点 针对于这
  • 笔记本重装系统后蓝屏记录

    大白菜制作U盘启动盘 刚好公司有个纯净版的系统iso镜像 然而重装系统的时候手贱勾选了USB3 0的驱动 导致安装后出现蓝屏 原因是驱动与设备不兼容导致 还以为是系统的问题 原先都是安装雨木林风的ghost版本 到没遇到这个问题 今天可把我
  • MySQL笔记(1)安装MySQL5.6

    知识来源 PHP与MySQL程序设计 第四版 yum 安装MySQL 禁用selinux sudo sed i s SELINUX enforcing SELINUX disabled etc selinux config 重启服务器后 查
  • saltstack的配置管理与数据系统

    saltstack的配置管理与数据系统 1 YAML语言 1 1 YAML的基本规则 2 使用SaltStack配置一个apache实例 2 1 在Master上部署sls配置文件并执行 3 使用SaltStack在minion02上配置n
  • 一小时学会js-b站笔记

    Javascript中代理的代码示例 Proxy 代理 const obj name 吴昊 age 18 const container document getElementById const p1 new Proxy obj get
  • 启动roketMq 错误: 找不到或无法加载主类 Files\Java\jdk1.8.0_291\jre\lib\ext

    安装roketMQ出现报错 检查mq的环境变量配置无误 最后锁定到Java环境变量 测试java javac java version都正常 那就蛋疼了 最后一看jdk是安装在Program Files目录下的 问题就出在这里 卸载JDK
  • 在Linux系统里使用Apache搭建Web网站服务器

    使用Apache搭建Web网站服务器 Apache服务 Apache被研发于1995年 是纯开源软件 用于HTTP协议提供web浏览服务 可在Unix Linux Windows上运行 1 配置静态IP vim etc sysconfig
  • 多线程(同步)

    一 为什么要使用线程同步 1 什么是同步 同步就是协同步调 按预定的先后次序进行运行 如 你用完 其它人才能用 同 字从字面上容易理解为一起 其实不是 同 字应是指协同 协助 互相配合 当有一个线程在对内存进行操作时 其他线程都不可以对这个
  • Java学习笔记9——封装

    封装 什么是封装 封装的原则 private关键字的使用 this关键字 this的内存原理 什么是封装 封装是面向对象的三大特征之一 封装 继承 多态 是面向对象编程语言对客观世界的模拟 客观世界的成员变量都是隐藏在对象内部的 外部无法直
  • python: openpyxl写入文件打开后显示文件损坏

    最近在将字典数据写入excel时 运用了openpyxl 点击运行 代码运行正常 但是跑了一晚上数据 打开文件时 居然显示 部分内容有问题 文件已损坏 经过多次测试 上网搜索无结果后 更改代码中的wb active为wb ws Sheet1
  • ESP32引脚参考

    原文链接 ESP32引脚参考 您应该使用哪个GPIO引脚 360doc个人图书馆 总结的相当全面 ESP32简单易懂的GPIO使用注意事项 首先上图 GPIO建议列表 特别的在硬件上要注意使用外接模块时不能将GPIO12拉高 否则将导致ES
  • 依托 axios 实现全局请求防抖

    更新 该方法已过时 此 API 自 v0 22 0 起已弃用 传送门 新的代替方案是 AbortController 并且 前端取消请求无法真实取消 原因在于请求发送到服务器后服务器或许已经做了处理 但是前端只是关闭了返回通道 可是实际上服