取消网络请求

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"); // 取消第一个请求
相关推荐
上去我就QWER9 分钟前
Qt中如何获取系统版本信息
开发语言·qt
我是苏苏1 小时前
C#高级:程序查询写法性能优化提升策略(附带Gzip算法示例)
开发语言·算法·c#
木木子99991 小时前
业务架构、应用架构、数据架构、技术架构
java·开发语言·架构
qq_5470261793 小时前
Flowable 工作流引擎
java·服务器·前端
刘逸潇20054 小时前
CSS基础语法
前端·css
吃饺子不吃馅5 小时前
[开源] 从零到一打造在线 PPT 编辑器:React + Zustand + Zundo
前端·svg·图形学
小马哥编程5 小时前
【软考架构】案例分析-Web应用设计(应用服务器概念)
前端·架构
鱼与宇6 小时前
苍穹外卖-VUE
前端·javascript·vue.js
啃火龙果的兔子6 小时前
前端直接渲染Markdown
前端
z-robot6 小时前
Nginx 配置代理
前端