当前位置: 首页 > news >正文

web原生API AbortController网络请求取消方法使用介绍:防止按钮重复点击提交得最佳方案

在前端开发中,取消网络请求是一个常见的需求,尤其是在用户频繁操作或需要中断长时间请求的场景下。

AbortController 主要用于 ​优雅地管理和取消异步操作:

浏览器原生 API


一、代码解析

1. ​创建 AbortController 实例
const controller = new AbortController();
  • 作用:实例化一个 AbortController 对象,用于生成 AbortSignal 信号对象。
  • 返回值controller 包含两个属性:
    • signal:用于传递给支持取消的 API的信号对象
    • abort():调用此方法会触发信号的中止逻辑

2. ​发起可取消的 fetch 请求
fetch(url, { signal }).then(response => response.json()).catch(error => {if (error.name === 'AbortError') {console.log('请求已取消');}});
关键点
  • 将 controller.signal 作为 fetch 的第二个参数传入,使请求与信号关联
  • 当 controller.abort() 被调用时,fetch 请求会检测到 signal.aborted 为 true,终止请求并抛出 AbortError
  • 错误处理:通过 catch 捕获错误,判断 error.name === 'AbortError' 以区分请求是否被主动取消

3. ​终止请求
controller.abort(); // 终止请求

原理==信号机制==:

  • AbortController 通过 signal 对象实现跨 API 的取消信号传递
  • 当 abort() 被调用时,所有关联的 signal 会触发 abort 事件,通知相关操作终止


一、核心应用场景

1.​取消网络请求

在用户频繁操作(如快速切换页面、重复提交表单)时,避免因多个未完成的请求导致 ​竞态条件

示例:用户连续点击“加载数据”按钮时,仅保留最后一次请求的结果,中断之前的请求

const controller = new AbortController();
fetch(url, { signal }).then(response => response.json()).catch(error => {if (error.name === 'AbortError') {console.log('请求已取消');}});
controller.abort(); // 终止请求

2.超时控制

结合 AbortSignal.timeout() 自动终止超时请求,避免长时间等待无响应的接口 

fetch('/api/data', { signal: AbortSignal.timeout(5000) }) // 5秒超时.then(response => response.json()).catch(error => {if (error.name === 'TimeoutError') {console.log('请求超时');}});

二、实际应用场景

1.​搜索框防抖取消


用户连续输入时,仅保留最后一次请求
const search = debounce(async (query) => {if (controller.value) controller.value.abort();controller.value = new AbortController();const response = await fetch(`/api/search?q=${query}`, { signal: controller.value.signal });// 更新搜索结果
}, 300);

2.分页加载控制

切换分页时取消上一页请求:

const loadPage = async (page) => {if (controller.value) controller.value.abort();controller.value = new AbortController();const data = await fetch(`/api/data?page=${page}`, { signal: controller.value.signal });// 渲染新数据
};

三、技术优势

  1. 统一控制流
    通过单一 AbortController 实例管理多个异步操作,简化代码逻辑 

  2. 避免资源浪费
    及时终止无效请求,减少网络带宽和服务器压力 

  3. 兼容性适配
    现代浏览器广泛支持,低版本环境可通过 Polyfill 兼容 
http://www.xdnf.cn/news/61021.html

相关文章:

  • 数码管静态显示一位字符(STC89C52单片机)
  • QT 的.pro 转 vsproject 工程
  • C++ 2025 展望:现代编程需求与新兴技术驱动下的变革
  • 目标检测篇---R-CNN梳理
  • 多线程出bug不知道如何调试?java线程几种常见状态
  • 讯联桌面TV版apk下载-讯联桌面安卓电视版免费下载安装教程
  • Python-Django系列—部件
  • 天翼云手机断开连接2小时关机
  • 2025大模型十大安全威胁(OWASP TOP 10 LLM 2025).pdf
  • 基于MuJoCo物理引擎的机器人学习仿真框架robosuite
  • Python常用的第三方模块【openpyxl库】读写Excel文件
  • 机器学习-08-推荐算法-案例
  • C# .NET如何自动实现依赖注入(DI)
  • AI大模型如何重塑科研:从灵感生成到学术写作的全链路变革
  • CH585单片机的LCD外设怎么驱动段式LCD
  • 【matlab】地图上的小图
  • 基于Java的不固定长度字符集在指定宽度和自适应模型下图片绘制生成实战
  • Linux学习笔记协议篇(六):SPI FLASH设备驱动
  • 华为VRP系统知识总结及案例试题
  • 下载pycharm遇到的问题及解决方法
  • 深度学习3.5图像分类数据集
  • elastic/go-elasticsearch与olivere/elastic
  • 乐家桌面安卓版2025下载-乐家桌面软件纯净版安装分享码大全
  • 【scikit-learn基础】--『监督学习』之 均值聚类
  • GPT,Genini, Claude Llama, DeepSeek,Qwen,Grok,选对LLM大模型真的可以事半功倍!
  • 发布事件和Insert数据库先后顺序
  • GeoJSON 格式详解与使用指南
  • Macbook IntelliJ IDEA终端无法运行mvn命令
  • 【2025面试Java常问八股之redis】zset数据结构的实现,跳表和B+树的对比
  • 1.Vue3 - 创建Vue3工程