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

AbortController 取消请求

‌AbortController‌是JavaScript中的一个全局类,主要用于中止各种异步操作,包括网络请求、事件监听器、可写流和数据库事务等。通过提供一个AbortSignal对象,AbortController允许开发者在需要时自由地终止这些操作,避免不必要的开销或冗长的等待‌

基本用法

‌创建AbortController实例‌:通过new AbortController()创建一个控制器实例。
‌获取signal对象‌:通过controller.signal获取一个AbortSignal对象,该对象可以传递给需要中止的API。
‌中止操作‌:调用controller.abort()方法会触发与该控制器关联的所有操作的中止。可选地,可以传递一个原因或错误给abort()方法,以便进行更细粒度的处理‌

常见使用场景

‌网络请求‌:在发起fetch请求时,可以将AbortController的signal对象作为fetch选项的第二个参数,从而可以在需要时通过调用abort()方法来取消请求‌
‌事件监听器‌:在添加事件监听器时,可以将signal对象作为选项传递给addEventListener,这样当调用abort()方法时,所有绑定到该信号的事件监听器都会被触发中止事件‌

‌定时器和间隔调用‌:在设置定时器或间隔调用时,可以将signal对象传递给相关函数,从而可以在需要时通过调用abort()方法来取消定时器或间隔调用‌

示例代码

以下是一个使用AbortController中止fetch请求的示例代码:

async function fetchWithTimeout(url, timeout = 5000) {const controller = new AbortController();const signal = controller.signal;const timeoutId = setTimeout(() => controller.abort(), timeout);try {const response = await fetch(url, { signal });clearTimeout(timeoutId);return await response.json();} catch (error) {if (error.name === 'AbortError') {console.log('请求被中止');} else {console.error('请求失败', error);}}
}

在这个示例中,我们创建了一个AbortController实例,并将其signal对象传递给fetch选项。如果超过指定的超时时间,定时器会调用abort()方法中止fetch请求‌

相关文章:

  • C++23 std::byteswap:反转字节 (P1272R4)
  • 征战高端10余载,OPPO少了昔日的锐气
  • 链表反转_leedcodeP206
  • 如何查看和验证AWS CloudFront的托管区域ID
  • Vue + ECharts 实现多层极坐标环形图
  • 通过AWS Console连接服务器,简化运维过程
  • 企业出海降本:如何将应用从 AWS EC2 快速无缝迁移至DigitalOcean Droplet
  • 揭开应用程序的神秘面纱:深入了解 AWS X-Ray
  • 【docker】启动临时MongoDB容器、挂载数据卷运行数据库服务,并通过备份文件恢复MongoDB数据库备份数据
  • SQLMesh增量模型实战指南:时间范围分区
  • nginx 核心功能
  • 鸟笼效应——AI与思维模型【84】
  • 组件轮播与样式结构重用实验
  • Android开发——实现一个计算器
  • 利用3DMAX + Corona Renderer打造现代住宅逼真效果!
  • DotNet 入门:(一) 环境安装
  • MarkItDown:如何高效将各类文档转换为适合 LLM 处理的 Markdown 格式
  • 进程优先级以及切换调度
  • 得物 小程序 6宫格 分析
  • C++/SDL 进阶游戏开发 —— 双人塔防(代号:村庄保卫战 16)
  • 2025年“投资新余•上海行”钢铁产业“双招双引”推介会成功举行
  • 向总书记汇报具身智能发展的“稚辉君”:从期待到兴奋再到备受鼓舞
  • 君亭酒店:2024年营业收入约6.76亿元, “酒店行业传统增长模式面临巨大挑战”
  • 四川省社科联期刊:不建议在读硕士、博士将导师挂名为第一作者
  • 李强主持召开国务院常务会议
  • 广州一人均500元的日料店回收食材给下一桌?市场监管部门介入调查