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

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请求‌

http://www.xdnf.cn/news/2935.html

相关文章:

  • Lucene 分词工具全解析与对比指南
  • PDF Shaper v15.0
  • AI工具的应用体验---------一键生成个人的微信名片
  • Linux Vim 使用 显示行号、替换、查找、多文件打开等骚操作
  • 双重差分模型学习笔记(理论)
  • Vue2 相关知识点整理
  • 从技术视角解析百度文库AI的核心竞争力与行业启示
  • 【统计方法】交叉验证:Resampling, nested 交叉验证等策略 【含R语言】
  • 非凸科技受邀出席AI SPARK活动,共探生成式AI驱动金融新生态
  • Vue3 Echarts 3D圆形柱状图实现教程以及封装一个可复用的组件
  • 高效 Transformer 的综述
  • AGILE:开启LLM Agent强化学习的创新框架
  • CSdiy java 06
  • Spark,集群搭建-Standalone
  • 小结:PKI(Public Key Infrastructure,公钥基础设施)
  • Python爬虫(10)Python数据存储实战:基于pymongo的MongoDB开发深度指南
  • npm打包内存不足- JavaScript heap out of memory
  • SQLMesh增量模型实战指南:时间范围分区
  • 对比测评:为什么AI编程工具需要 Rules 能力?
  • 借助云蝠智能大模型呼叫,打造企业招聘竞争力
  • 如何强制触发 OpenShift 节点的 MachineConfig 更新
  • GC的查看
  • MySQL事务隔离级别的实现原理MVCC
  • 今日行情明日机会——20250429
  • UEC++第15天|番茄插件、实现跳跃、实现背景运动
  • JavaScript高级进阶(五)
  • 豪越科技消防立库方案:实现应急物资高效管理
  • 链表的中间节点
  • 机器视觉算法与应用:企业级开发全流程详解
  • Kotlin -> lateinit 和 lazy 详解