文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Vue中Axios中取消请求及阻止重复请求的方法

2024-04-02 19:55

关注

阻止请求目的:

为了防止用户在网络不好或者其他情况下短时间内重复进行接口请求,从而导致前端向后端重复发送多次请求。

常见情况:

PC端:输入框搜素,多次请求接口移动端:移动端很容易造成误操作或多操作请求(移动端没有点击延迟)
注意:有Loading遮罩时也有可能发生重复请求

新建 axios.js 文件

在这里插入图片描述

import axios from "axios";
// import router from "../js/router";
// import {  Message } from "element-ui";

function getRequestKey(config) {
    let {
        method,
        url,
        params,
        data
    } = config;
    // axios中取消请求及阻止重复请求的方法
    // 参数相同时阻止重复请求:
    // return [method, url, JSON.stringify(params), JSON.stringify(data)].join("&");
    // 请求方法相同,参数不同时阻止重复请求
    return [method, url].join("&");
}


let pendingRequest = new Map();

function addPendingRequest(config) {
    // console.log(config.url)
    let requestKey = getRequestKey(config);
    config.cancelToken = config.cancelToken || new axios.CancelToken((cancel) => {
        if (!pendingRequest.has(requestKey)) {
            pendingRequest.set(requestKey, cancel);
        }
    });
}


function removePendingRequest(config) {
    let requestKey = getRequestKey(config);
    if (pendingRequest.has(requestKey)) {
        // 如果是重复的请求,则执行对应的cancel函数
        let cancel = pendingRequest.get(requestKey);
        cancel(requestKey);
        // 将前一次重复的请求移除
        pendingRequest.delete(requestKey);
    }
}


axios.interceptors.request.use(
    function (config) {
        // 检查是否存在重复请求,若存在则取消已发的请求
        removePendingRequest(config);
        // 把当前请求信息添加到pendingRequest对象中
        addPendingRequest(config);
        return config;
    },
    function (error) {
        return Promise.reject(error);
    }
);


axios.interceptors.response.use(
    function (response) {
        // 对响应数据做点什么
        removePendingRequest(response.config);
        // 该方法是项目中用到
        // if (response.data.message == "您没有获得授权") {
        //     Message({
        //         type: "warning",
        //         message: "您没有获得授权,请重新登录",
        //     });
        //     localStorage.removeItem('token');
        //     localStorage.removeItem('data');
        //     router.push({
        //         name: "login",
        //     });
        // }
        return response;
    },
    function (error) {
        // 从pendingRequest对象中移除请求
        removePendingRequest(error.config || {});
        if (axios.isCancel(error)) {
            console.log("被取消的重复请求:" + error.message);
        }
        return Promise.reject(error);
    }

);
export default axios

全局 main.js 引入

import Vue from "vue";
import axios from "./until/axios";
Vue.prototype.$axios = axios;

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

 到此这篇关于Vue中Axios中取消请求及阻止重复请求的方法的文章就介绍到这了,更多相关Axios取消请求及阻止重复请求内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-前端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯