使用【AbortController】终止请求

AbortController 是一个 Web API,用于终止一个或多个 Web 请求。当你使用 fetch API 发送异步请求时,你可能需要在某些情况下主动终止这些请求。使用 AbortController 可以实现这一功能。

基本用法:

  1. 创建一个 AbortController 实例:

    javascript 复制代码
    const controller = new AbortController();
  2. 通过 controller.signal 获取信号,并在 fetch 请求中使用它:

    javascript 复制代码
    fetch(url, { signal: controller.signal })
      .then(response => response.json())
      .then(data => console.log(data))
      .catch(err => {
        if (err.name === 'AbortError') {
          console.log('Fetch aborted');
        } else {
          console.error('Fetch error:', err);
        }
      });
  3. 终止请求 : 当你需要取消 fetch 请求时,可以调用 controller.abort() 方法。

    javascript 复制代码
    controller.abort();

使用 AbortController 可以让你更好地控制资源和提高应用的性能,尤其是在处理需要长时间等待的请求或者在组件卸载时取消未完成的请求时非常有用。

笔者在react中取消请求,遇到了此问题,记录一下,共勉!

相关推荐
上山打牛3 分钟前
cornerstone3D 通过二进制渲染影像
前端
一只小阿乐8 分钟前
react路由中使用context
前端·javascript·react.js·context 上下文
Hilaku8 分钟前
一周狂揽40K+ Star⭐ 的 Pretext 到底有多变态?
前端·javascript·html
Southern Wind11 分钟前
AI Skill Server 动态技能中台
前端·后端·mysql·node.js
锦木烁光32 分钟前
多端项目太乱?我是这样用 Monorepo 重构的
前端·架构
上山打牛36 分钟前
cornerstone3D基本使用
前端
阿鑫_99637 分钟前
通用-Nvm基础知识
前端
xinzheng新政42 分钟前
Javascript·深入学习基础知识
前端·javascript·学习
前端付豪1 小时前
实现记忆开关
前端·后端
前端开发呀1 小时前
约定式路由的极简主义实践:一个插件搞定 React/Vue × Vite/Rspack
前端