Vue3取消网络请求的方法(AbortController)

在 Vue3 中,已经发出的请求是否可以被取消,取决于你使用的 HTTP 客户端库 。Vue3 本身不直接处理 HTTP 请求,但通常搭配 Axios 或原生 fetch 使用。以下是两种主流方案的取消方法:


1. 使用 Axios + CancelToken

Axios 提供了 CancelToken 机制(新版推荐 AbortController,但 CancelToken 仍可用)。

javascript

复制代码
import axios from 'axios';

// 在 Vue3 组件中
export default {
  setup() {
    const cancelTokenSource = axios.CancelToken.source();

    const fetchData = async () => {
      try {
        const response = await axios.get('/api/data', {
          cancelToken: cancelTokenSource.token
        });
        // 处理响应
      } catch (error) {
        if (axios.isCancel(error)) {
          console.log('请求被取消:', error.message);
        } else {
          // 处理其他错误
        }
      }
    };

    // 取消请求的方法
    const cancelRequest = () => {
      cancelTokenSource.cancel('用户主动取消请求');
    };

    return { fetchData, cancelRequest };
  },
};

2. 使用 Fetch API + AbortController

原生 fetch 可通过 AbortController 取消请求。

javascript

复制代码
// 在 Vue3 组件中
export default {
  setup() {
    let abortController = new AbortController();

    const fetchData = async () => {
      try {
        const response = await fetch('/api/data', {
          signal: abortController.signal
        });
        // 处理响应
      } catch (error) {
        if (error.name === 'AbortError') {
          console.log('请求被取消');
        } else {
          // 处理其他错误
        }
      }
    };

    // 取消请求的方法
    const cancelRequest = () => {
      abortController.abort();
      // 重新创建 Controller,以便下次请求使用
      abortController = new AbortController();
    };

    return { fetchData, cancelRequest };
  },
};

最佳实践

  • 在组件卸载时自动取消

    利用 Vue3 的生命周期钩子 onBeforeUnmount,避免组件卸载后仍更新状态。

javascript

复制代码
import { onBeforeUnmount } from 'vue';

export default {
  setup() {
    const abortController = new AbortController();

    const fetchData = async () => {
      // ... 使用 abortController.signal
    };

    onBeforeUnmount(() => {
      abortController.abort();
    });

    return { fetchData };
  },
};
  • 封装自定义 Hook

    使用 Composition API 封装可复用的请求逻辑。

javascript

复制代码
// useFetch.js
import { ref, onBeforeUnmount } from 'vue';

export function useFetch(url) {
  const data = ref(null);
  const error = ref(null);
  const abortController = new AbortController();

  const fetchData = async () => {
    try {
      const response = await fetch(url, { signal: abortController.signal });
      data.value = await response.json();
    } catch (e) {
      if (e.name !== 'AbortError') error.value = e;
    }
  };

  onBeforeUnmount(() => abortController.abort());

  return { data, error, fetchData, cancel: () => abortController.abort() };
}

关键点总结

  • Axios :使用 CancelToken.source()AbortController(Axios >= 0.22.0)。

  • Fetch :必须依赖 AbortController

  • 组件销毁时清理:通过生命周期钩子自动取消未完成的请求,避免内存泄漏。

  • 错误处理:捕获取消错误,避免与常规错误混淆。

根据项目使用的库选择对应方案即可实现请求取消。

相关推荐
不瘦80斤不改名11 分钟前
HTML基础(一)
开发语言·前端·html
UXbot13 分钟前
AI画原型工具如何帮非设计师快速生成UI界面
前端·vue.js·ui·kotlin·swift·原型模式·web app
前端若水16 分钟前
原生嵌套(Nesting):以后还写 SCSS 吗?
前端·css·scss
兄弟加油,别颓废了。22 分钟前
系统全功能详细操作手册,从启动到测试
前端·chrome
ZC跨境爬虫39 分钟前
跟着 MDN 学 HTML day_32:(AbstractRange 抽象接口与 DOM 范围操作)
前端·javascript·ui·html·音视频
十子木43 分钟前
设置把所有终端移动到最前端的快捷键
前端
陈老老老板1 小时前
Bright Data Web Scraping 实战:用 MCP + Dify 构建 eBay 商品详情采集 AI 工作流(2026)
前端·人工智能
一渊之隔1 小时前
uniapp蓝牙搜索连接展示蓝牙设备包含信号显示
前端·网络·uni-app·bluetooth
Cisyam^1 小时前
Bright Data Web Scraper 实战:构建 TikTok 与 LinkedIn Web Scraping 自动化 Skill(2026)
运维·前端·自动化
李剑一1 小时前
开箱即用!Vue3+TS 视频组件完整代码,自动提取视频第一帧做封面。妈妈再也不用担心我手动截封面了
前端