千家信息网

vue中axios怎么实现重复点击取消上一次请求封装

发表于:2024-11-30 作者:千家信息网编辑
千家信息网最后更新 2024年11月30日,本篇内容主要讲解"vue中axios怎么实现重复点击取消上一次请求封装",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"vue中axios怎么实现重复点击取消
千家信息网最后更新 2024年11月30日vue中axios怎么实现重复点击取消上一次请求封装

本篇内容主要讲解"vue中axios怎么实现重复点击取消上一次请求封装",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"vue中axios怎么实现重复点击取消上一次请求封装"吧!

使用场景

重复点击或者多tab标签使用一个视图等(当然也可以用加载中或者透明背景禁止请求中再次点击)

封装代码

来自于互联网

let pending = []; //声明一个数组用于存储每个请求的取消函数和axios标识let cancelToken = axios.CancelToken;let removePending = (config) => { for(let p in pending){  if(pending[p].u === config.url + '&' + config.method) { //当当前请求在数组中存在时执行函数体   pending[p].f(); //执行取消操作   pending.splice(p, 1);   } }}// http请求拦截器axios.interceptors.request.use(config => { removePending(config); //在一个axios发送前执行一下取消操作 config.cancelToken = new cancelToken((c)=>{  // 这里的axios标识我是用请求地址&请求方式拼接的字符串,当然你可以选择其他的一些方式  pending.push({ u: config.url + '&' + config.method, f: c });  });  return Promise.resolve(config)}, error => { return Promise.reject(error)})// http响应拦截器axios.interceptors.response.use(data => {   removePending(data.config); //在一个axios响应后再执行一下取消操作,把已经完成的请求从pending中移除  return Promise.resolve(data) }, error => { //加载失败 return {'data':{}} // return Promise.reject(error)})

经过多次测试发现不同请求也给我取消了,原因是没有校验请求参数,也就是说get请求可以用,修改以下代码

pending.push({ u: config.url + '&' + config.method, f: c });

修改为:

pending.push({ u: config.url + JSON.stringify(config.data) +'&' + config.method, f: c });//config.data为请求参数

上面判断也需要修改,这样get请求和post都可以用了

到此,相信大家对"vue中axios怎么实现重复点击取消上一次请求封装"有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

0