取消网络请求

1. 使用 fetch 的取消请求

fetch 使用 AbortController 提供取消请求的功能。

示例代码
javascript 复制代码
let currentController = null;

function fetchWithCancel(url) {
    // 如果有上一个请求,则取消它
    if (currentController) {
        currentController.abort();
    }

    // 创建新的 AbortController
    currentController = new AbortController();
    const signal = currentController.signal;

    fetch(url, { signal })
        .then(response => response.json())
        .then(data => {
            console.log("fetch 数据:", data);
        })
        .catch(error => {
            if (error.name === "AbortError") {
                console.log("fetch 请求被取消");
            } else {
                console.error("fetch 请求出错:", error);
            }
        });
}

// 示例调用
fetchWithCancel("https://api.example.com/data");
fetchWithCancel("https://api.example.com/otherdata"); // 取消第一个请求

2. 使用 axios 的取消请求

axios 使用 CancelToken 提供取消请求的功能。CancelToken 是基于 Promise 的实现。

示例代码
javascript 复制代码
let currentCancelToken = null;

function axiosWithCancel(url) {
    // 如果有上一个请求,则取消它
    if (currentCancelToken) {
        currentCancelToken.cancel("axios 请求被取消");
    }

    // 创建新的 CancelToken
    currentCancelToken = axios.CancelToken.source();

    axios.get(url, {
        cancelToken: currentCancelToken.token,
    })
        .then(response => {
            console.log("axios 数据:", response.data);
        })
        .catch(error => {
            if (axios.isCancel(error)) {
                console.log(error.message); // 请求被取消
            } else {
                console.error("axios 请求出错:", error);
            }
        });
}

// 示例调用
axiosWithCancel("https://api.example.com/data");
axiosWithCancel("https://api.example.com/otherdata"); // 取消第一个请求
相关推荐
道不尽世间的沧桑16 分钟前
第9篇:插槽(Slots)的使用
前端·javascript·vue.js
bin915319 分钟前
DeepSeek 助力 Vue 开发:打造丝滑的滑块(Slider)
前端·javascript·vue.js·前端框架·ecmascript·deepseek
uhakadotcom37 分钟前
最新发布的Tailwind CSS v4.0提供了什么新能力?
前端
thinkMoreAndDoMore42 分钟前
深度学习(3)-TensorFlow入门(常数张量和变量)
开发语言·人工智能·python
GISer_Jing1 小时前
Node.js中如何修改全局变量的几种方式
前端·javascript·node.js
秋意钟1 小时前
Element UI日期选择器默认显示1970年解决方案
前端·javascript·vue.js·elementui
bramble1 小时前
Windows使用Trae全程提问来创建一个彩色贪吃蛇游戏,可以设置速度并查看游戏记录。
前端·程序员·trae
蓝桉8021 小时前
图片爬取案例
开发语言·数据库·python
逸狼1 小时前
【JavaEE进阶】Spring DI
java·开发语言
我命由我123452 小时前
微信小程序 - 自定义实现分页功能
前端·微信小程序·小程序·前端框架·html·html5·js