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请求的示例代码:

javascript 复制代码
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请求‌

相关推荐
独立开阀者_FwtCoder27 分钟前
MySQL FULLTEXT索引解析:为什么它能大幅提升文本搜索性能?
前端·javascript·面试
EndingCoder39 分钟前
React从基础入门到高级实战:React 实战项目 - 项目一:在线待办事项应用
前端·javascript·react.js·前端框架
一只帆記1 小时前
HTTP、WebSocket、SSE 对比
websocket·http
月下点灯1 小时前
使用Set集合新特性,快速实现一个商品SKU(单品)规格选择器
前端·javascript·vue.js
xphjj1 小时前
树形数据模糊搜索
前端·javascript·算法
我的div丢了肿么办1 小时前
HarmonyOS鸿蒙tabBar的详细讲解
前端·javascript·harmonyos
Bright16681 小时前
mkcert实现本地https
网络协议·http·https
渔舟唱晚@2 小时前
Axios 取消请求的演进:CancelToken vs. AbortController
javascript
2501_915921432 小时前
高敏感应用如何保护自身不被逆向?iOS 安全加固策略与工具组合实战(含 Ipa Guard 等)
websocket·网络协议·tcp/ip·http·网络安全·https·udp
GISer_Jing2 小时前
XHR / Fetch / Axios 请求的取消请求与请求重试
前端·javascript·网络