fetch 怎么获取到具体的错误原因?

2023-07-21 02:01:31 +08:00
 dzdh

网络层 比如 ERR_CONNECTION_RESETERR_NO_INTERNET_CONNECTION

代码逻辑的 AborController.reason('timeout') 怎么获取这个 timeout 呢。catch 里拿到的是AbortError: Fetch is abort 那 abort 的时候传的 reason 是干啥的

1491 次点击
所在节点    JavaScript
5 条回复
datou
2023-07-21 03:47:36 +08:00
这两种提示应该是浏览器的功能而不是 fetch 函数的功能
kkocdko
2023-07-21 07:49:20 +08:00
这个恐怕获取不到。

倒是可以用 AbortSignal 去控制中途提前终止,不知道对你是否有用。
tsanie
2023-07-21 08:53:49 +08:00
第一个不太清楚。

第二个问题,signal.reason 里可以获取你要的'timeout'
tsanie
2023-07-21 08:57:30 +08:00
换句话说,reason 不包含在 error 里

const controller = new AbortController();
const signal = controller.signal;

fetch(url, { signal }).catch(err => console.log(`reason: ${signal.reason}, error: ${err.message}`));
controller.abort('timeout');
chnwillliu
2023-07-21 09:04:41 +08:00
abort signal 都是你自己传给 fetch 的,fetch 跟你说发生错误了,错误是 abortError ,你自己拿着刚刚传给 fetch 的 signal 一看不就知道 signal.reason 是什么。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/958465

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX