广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >Vue中Axios中取消请求及阻止重复请求的方法
  • 745
分享到

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

2024-04-02 19:04:59 745人浏览 八月长安
摘要

目录阻止请求目的:常见情况:新建 axiOS.js 文件全局 main.js 引入阻止请求目的: 为了防止用户在网络不好或者其他情况下短时间内重复进行接口请求,从而导致前端向后端重复

阻止请求目的:

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

常见情况:

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取消请求及阻止重复请求内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Vue中Axios中取消请求及阻止重复请求的方法

本文链接: https://www.lsjlt.com/news/139219.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Vue中Axios中取消请求及阻止重复请求的方法
    目录阻止请求目的:常见情况:新建 axios.js 文件全局 main.js 引入阻止请求目的: 为了防止用户在网络不好或者其他情况下短时间内重复进行接口请求,从而导致前端向后端重复...
    99+
    2022-11-13
  • 浅谈axios中取消请求及阻止重复请求的方法
    目录前言核心——CancelToken实际应用和封装一些小细节前言 在实际项目中,我们可能需要对请求进行“防抖”处理。这里主要是为了阻...
    99+
    2022-11-12
  • Axios中怎么取消重复请求
    这篇文章将为大家详细讲解有关Axios中怎么取消重复请求,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。一、如何取消请求Axios 是一个基于 Promise...
    99+
    2022-10-19
  • 前端取消请求及取消重复请求方式
    目录一、前言二、项目准备三、原生方法四、promise五、借助Promise.race六、总结一、前言 今天,我想跟大家分享几种前端取消请求的几种方式。 相信大家在平时的开发中,肯定...
    99+
    2022-11-13
  • Axios取消重复请求的方法实例详解
    目录前言一、如何取消请求二、如何判断重复请求三、如何取消重复请求3.1 定义辅助函数3.2 设置请求拦截器3.3 设置响应拦截器四、CancelToken 的工作原理五、总结六、参考...
    99+
    2022-11-12
  • vue axios拦截器常用之重复请求取消
    引言 上一篇介绍了axios的简单封装,知道了axios拦截器的应用场景和方法,今天来看一下对于响应时间过长且请求次数过高的情况拦截器如何处理。 取消请求的方法 Axios使用内部...
    99+
    2022-11-12
  • Vue路由切换和Axios接口取消重复请求详解
    目录前言场景解决方案axios中如何取消请求项目中封装使用总结参考前言 在日常前端开发中, 经常会遇到频繁发起的重复请求, 会给服务器及网络造成不必要的压力, 可通过取消重复请求解决...
    99+
    2022-11-13
  • vue中axios如何实现重复点击取消上一次请求封装
    这篇文章主要为大家展示了“vue中axios如何实现重复点击取消上一次请求封装”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“vue中axios如何实现重复点击取...
    99+
    2022-10-19
  • vue axios中的get请求方式
    目录vue axios中的get请求一、安装二、使用常见错误vue axios post请求参数错误400vue axios中的get请求 一、安装 使用 npm:npm insta...
    99+
    2022-11-13
  • vue axios数据请求及vue中使用axios的示例分析
    这篇文章将为大家详细讲解有关vue axios数据请求及vue中使用axios的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。axios 简介axios 是一个基...
    99+
    2022-10-19
  • vue axios中的get请求方式是什么
    这篇文章主要讲解了“vue axios中的get请求方式是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue axios中的get请求方式是什么”吧!vue axi...
    99+
    2023-07-02
  • vue中如何实现基于axios的ajax请求方法
    小编给大家分享一下vue中如何实现基于axios的ajax请求方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!如下所示:imp...
    99+
    2022-10-19
  • vue中如何使用axios数据请求get、post方法
    小编给大家分享一下vue中如何使用axios数据请求get、post方法,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!vue中使用axios方法我们先安装axios这个方法npm inst...
    99+
    2022-10-19
  • Vue3在Setup中使用axios请求获取的值方式
    目录Setup中使用axios请求获取的值Vue3+Setup使用知识点Setup中使用axios请求获取的值 上次我们使用axios给项目搞上了网络请求,从此项目数据不再是静态的。...
    99+
    2022-11-13
  • vue中的axios配置及接口请求路径api配置
    目录简介一、axios配置二、请求接口路径api配置三、axios和接口api的全局注入四、请求接口的使用方式注意简介 关于vue中使用axios请求的配置,注意其中区分Vue2.0...
    99+
    2022-11-13
  • java中springMVC获取请求参数的方法
    目录原生方式获取请求参数控制器方法形参获取请求参数@RequestParam注解@RequestHeader注解@CookieValue注解通过POJO获取请求参数原生方式获取请求参...
    99+
    2023-05-18
    springMVC 请求参数 springMVC 请求
  • vue中发送请求的方法是什么
    这篇文章主要讲解了“vue中发送请求的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue中发送请求的方法是什么”吧! ...
    99+
    2022-10-19
  • React中使用axios发送请求的几种常用方法
    目录React中安装并引入axios依赖 使用axios进行GET请求 使用axios.get方式 使用axios(config {...}) 使用axios进行POST请求 使用a...
    99+
    2022-11-12
  • SpringBoot2中使用@RequestHeader获取请求头的方法
    目录一、使用@RequestHeader获取请求头(一)获取某一个请求头(二)获取数值型请求头(三)一次性获取所有请求头二、@RequestHeader注解详解(一)name、val...
    99+
    2022-11-12
  • Spring Boot中获取request的三种方式及请求过程
    目录一、请求过程二、获取request的三种方式2.1、可以封装为静态方法2.2、controller的方法里面2.3、直接注入三、request常用API3.1、request路径...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作