当前位置: 首页 > 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 兼容 

相关文章:

  • 总结设计测试用例的万能公式
  • 基于LLM的响应式流式处理实践:提升用户体验的关键技术
  • 算法 | 鲸鱼优化算法(WOA)原理,公式,应用,算法改进研究综述,完整matlab代码
  • 测试用例书写规范详解:构建高效测试体系的基础
  • STM32H5开发陀螺仪LSM6DSV16X(3)----SFLP获取四元数
  • spring boot使用Scheduling实现动态增删启停定时任务
  • 8051单片机所有Keil C51汇编伪指令和C语言关键字大全
  • DAG(有向无环图)计算模型面试内容整理-DAG的特点和应用场景
  • Python第一周作业
  • 大模型学习笔记 day01 提示工程入门1.One-shot Few-shot提示学习法
  • XSS详解
  • Oracle RMAN同步数据库Active database duplicate
  • Elasticsearch中的_source字段讲解
  • YOLOv12综述:基于注意力的增强与先前版本的对比分析
  • Spring MVC 执行流程全解析:从请求到响应的七步走
  • JavaWeb学习打卡-Day1-分层解耦、Spring IOC、DI
  • 实践项目开发-hbmV4V20250407-readme
  • Redis 慢查询分析与优化
  • 2025 年职业院校技能大赛网络建设与运维赛项Docker赛题解析
  • JS省市区三级联动查询示例代码(城市查询、地区查询)
  • 机器人马拉松背后的五大启示:未来社会与机器人的深度融合
  • 深一度|中国花样滑冰因何大滑坡
  • 美军一天内对也门发动50余次袭击,胡塞武装称再次击落美军无人机
  • 85岁眼科专家、武汉大学人民医院原眼科主任喻长泰逝世
  • 上海这台人形机器人完成半马:无故障、无摔倒,冲过终点不忘挥手致意
  • 错失两局领先浪费赛点,王楚钦不敌雨果无缘世界杯男单决赛