js实现axios限制请求队列

作者:Tzyito 时间:2024-05-10 13:59:31 

背景是:

在实际开发中,可能会遇到网络问题或者查询量比较大的情况,上一个请求还没有完成,用户就发起了下一个请求。

会造成什么情况呢?

但是同一个请求多次发送到服务器,无疑是对服务器的一种压力,所以需要在已经优化服务器过查询速度后,以及用户网络情况比较差的条件下,在前端进行请求限制。

axios 自带的cancelToken可以帮我们实现这个需求,并且提供给了我们一个现成的api axios.CancelToken ,这是一个返回值是带有请求信息的回调函数,我们可以在需要cancel的时候去执行这个回调函数。具体实现如下:


const service = axios.create({});
const penddingMap = new Map();
const addPendding = (config) => {
config.cancelToken = config.cancelToken || new axios.CancelToken(cancel => {
 if(!penddingMap.has(config.url)){
  penddingMap.set(config.url,cancel);
 }
})
}

const removePendding = (config) => {
if(penddingMap.has(config.url)){
 let cancel = penddingMap.get(config.url);
   cancel(config.url);
   penddingMap.delete(config.url)
}
}

本地维护一个Map来存储每个请求信息, addPendding 中每次会去先判断是否有cancelToken,如果有就不用重新创建一个cancelToken。 removePendding 中判断请求信息是否在Map中,如果该请求存在于Map中,则执行cancel函数,并删除Map中的该请求。

* 中的具体应用:


service.interceptors.request.use(config => {
removePending(config) // 如果存在Map中先cancel该请求
 addPendding(config)  // 添加该请求到Map中
 return config
})

service.interceptors.response.use(response => {
``` // some code
 return response.data
},error => {
// 捕获cancel请求并抛出
 if(error instanceof Cancel){
   error.message = '上一请求尚未结束,稍等~';
   Message.error(error.message);
   return Promise.reject(error.response)
 // 这里抛出需要注意,在请求时调用try-catch进行捕获
 })
)

这里拦截成功后,就可以限制住大流量的多次请求。

这里只是一个例子,也可以通过判断按钮逻辑来控制用户是否发起请求。

来源:https://juejin.cn/post/6987673995541741575

标签:js,axios,限制请求,队列
0
投稿

猜你喜欢

  • JavaScript中CreateTextFile函数

    2024-04-18 10:49:03
  • 解析ROC曲线绘制(python+sklearn+多分类)

    2021-04-06 12:16:16
  • MySQL数据库中表的操作详解

    2024-01-26 20:37:27
  • python3.x实现base64加密和解密

    2023-12-17 00:30:33
  • ASP操作XML文件的完整实例

    2007-09-26 12:05:00
  • python openvc 裁剪、剪切图片 提取图片的行和列

    2022-07-03 15:29:40
  • Go学习笔记之Zap日志的使用

    2023-09-19 01:21:36
  • JS在IE和FireFox之间常用函数的区别小结

    2024-04-16 09:54:54
  • Python实现子类调用父类的方法

    2023-09-28 12:00:55
  • 单步调试 step into/step out/step over 区别说明

    2022-03-09 20:03:26
  • Python实现抓取城市的PM2.5浓度和排名

    2023-07-01 11:13:33
  • python绘图subplots函数使用模板的示例代码

    2023-05-23 06:05:01
  • Python图片转换成矩阵,矩阵数据转换成图片的实例

    2021-03-31 23:24:35
  • JS代码随机生成姓名、手机号、身份证号、银行卡号

    2024-04-18 09:35:36
  • 详解用Python调用百度地图正/逆地理编码API

    2021-06-01 16:35:39
  • python DataFrame转dict字典过程详解

    2022-08-16 20:59:08
  • python使用pdfminer解析pdf文件的方法示例

    2023-07-31 00:36:47
  • Python 批量刷博客园访问量脚本过程解析

    2023-11-23 21:30:14
  • Python中的groupby分组功能的实例代码

    2021-09-17 20:48:15
  • Python面向对象编程(一)

    2023-04-27 15:02:13
  • asp之家 网络编程 m.aspxhome.com