vue axios * 常用之重复请求取消

作者:小撕夜 时间:2023-07-02 17:03:21 

引言

上一篇介绍了axios的简单封装,知道了axios * 的应用场景和方法,今天来看一下对于响应时间过长且请求次数过高的情况 * 如何处理。

取消请求的方法

Axios使用内部提供的CancelToken来取消请求

官网示例1:用CancelToken.source工厂方法创建 cancel token,像这样


const CancelToken = axios.CancelToken;
const source = CancelToken.source();

axios.get('/user/12345', {
 cancelToken: source.token
}).catch(function(thrown) {
 if (axios.isCancel(thrown)) {
   console.log('Request canceled', thrown.message);
 } else {
    // 处理错误
 }
});

axios.post('/user/12345', {
 name: 'new name'
}, {
 cancelToken: source.token
})

// 取消请求(message 参数是可选的)
source.cancel('Operation canceled by the user.');

官网示例2:通过传递一个 executor 函数到 CancelToken 的构造函数来创建 cancel token:


const CancelToken = axios.CancelToken;
let cancel;

axios.get('/user/12345', {
 cancelToken: new CancelToken(function executor(c) {
   // executor 函数接收一个 cancel 函数作为参数
   cancel = c;
 })
});

// cancel the request
cancel();

可以看到上面都是在单个请求中创建的 cancel token 实际工作中我们需要对所有的请求都进行处理,接下来我们看下如何在 * 实现取消请求的功能

* 中取消重复请求


import axios from 'axios'
import baseURL from './config'
import qs from 'qs'

const pendingRequest = new Map(); // 请求对象
const CancelToken = axios.CancelToken;

axios.defaults.timeout = 30000
axios.defaults.baseURL = baseURL.target

// 添加请求 *
axios.interceptors.request.use(function(config) {
 // 在发送请求之前做些什么
 config.headers = {
     'content-type': 'application/json',
     'token': getToken()
 }
 // 获取请求key
 let requestKey = getReqKey(config);

// 判断是否是重复请求
 if (pendingRequest.has(requestKey)) { // 是重复请求
   removeReqKey(requestKey); // 取消
 }else{
   // 设置cancelToken
   config.cancelToken = new CancelToken(function executor(cancel) {
     pendingRequest.set(requestKey, cancel); // 设置
   })
 }

return config;
}, function (error) {
 // 请求错误
 return Promise.reject(error);
});

// 添加响应 *
axios.interceptors.response.use(function (response) {
 // 请求对象中删除requestKey
 let requestKey = getReqKey(response.config);
 removeReqKey(requestKey);

// 对返回数据做点啥 比如状态进行拦截
 if (response.data.status !== 200) {
     Toast({
       message: response.data.message,
       type: 'warning',
       duration: 1000
     })
     return
   }

// 没问题 返回服务器数据
 return response.data;
}, function (error) {
 let requestKey = getReqKey(error.config);
 removeReqKey(requestKey);

// 响应错误
 return Promise.reject(error);
});

// 获取请求key
function getReqKey(config) {
 // 请求方式、请求地址、请求参数生成的字符串来作为是否重复请求的依据
 const { method, url, params, data } = config; // 解构出来这些参数
 // GET ---> params  POST ---> data
 const requestKey =  [ method, url, qs.stringify(params), qs.stringify(data)].join('&');
 return requestKey;
}

// 取消重复请求
function removeReqKey(key) {
 const cancelToken = pendingRequest.get(key);
 cancelToken(key); // 取消之前发送的请求
 pendingRequest.delete(key); // 请求对象中删除requestKey
}

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

标签:axios, , ,请求
0
投稿

猜你喜欢

  • Python网络编程之Python编写TCP协议程序的步骤

    2022-12-25 17:18:55
  • Django Serializer HiddenField隐藏字段实例

    2022-10-29 02:39:07
  • JavaScript数据结构和算法之图和图算法

    2024-05-03 15:32:34
  • Python采集C站高校信息实战示例

    2023-11-16 12:01:56
  • rs.getrows的使用方法

    2008-04-05 14:01:00
  • 基于python全局设置id 自动化测试元素定位过程解析

    2022-04-28 18:52:08
  • Tensorflow: 从checkpoint文件中读取tensor方式

    2022-07-20 11:39:29
  • 奇妙的Javascript图片放大镜

    2024-04-30 08:51:22
  • 网站图片与文本谁更重要?(中英文对照)

    2008-10-17 10:25:00
  • Python中使用第三方库xlrd来读取Excel示例

    2022-04-22 06:29:41
  • MYSQL必知必会读书笔记 第一章(基础)

    2024-01-20 09:23:52
  • 使用Python3制作TCP端口扫描器

    2023-06-10 17:25:22
  • js显示世界时间示例(包括世界各大城市)

    2024-04-10 13:54:37
  • js实现固定显示区域内自动缩放图片的方法

    2024-04-16 09:51:35
  • asp中如何对ip段进行过滤限制

    2007-09-17 11:14:00
  • python使用PIL剪切和拼接图片

    2022-06-26 07:41:55
  • GO中 分组声明与array, slice, map函数

    2024-04-30 10:02:54
  • 详解Python中for循环的使用

    2023-06-13 13:55:40
  • 在tensorflow以及keras安装目录查询操作(windows下)

    2023-10-31 10:49:21
  • python之用Numpy和matplotlib画一个魔方

    2022-10-21 16:12:48
  • asp之家 网络编程 m.aspxhome.com