How to handle errors from setTimeout in JavaScript?(如何在JavaScript中处理来自setTimeout的错误?)
本文介绍了如何在JavaScript中处理来自setTimeout的错误?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
关于setTimeout
中的函数try
/catch
的简单问题
try {
setTimeout(function () {
throw new Error('error!');
}, 300)
} catch (e) {
console.log('eeee!')
console.log(e)
}
为什么捕获块不起作用?
我可以阅读有关此内容的哪些内容?
附注:问题是是否有可能处理这样的错误。不要回答承诺。推荐答案
计划与setTimeout
一起运行的函数在主循环中执行,在生成这些函数的代码体之外执行。
若要处理错误,请将try-catch
放在setTimeout
处理程序中:
setTimeout(function () {
try {
throw new Error('error!');
} catch (e) {
console.error(e);
}
}, 300)
如果需要从调用setTimeout
的块访问Error
对象,请使用Promises:
const promise = new Promise((resolve, reject) => {
setTimeout(function () {
try {
throw new Error('error!');
resolve(); // if the previous line didn't always throw
} catch (e) {
reject(e)
}
}, 300)
})
promise
.then(result => console.log("Ok " + result))
.catch(error => console.error("Ouch " + error))
上面的示例不是使用Promise
处理案例的最好方法。相反,实现如下delay(ms)
函数:
function delay(ms) {
return new Promise(resolve => setTimeout(resolve, ms))
}
然后调用
delay(300).then(myFunction).catch(handleError)
这篇关于如何在JavaScript中处理来自setTimeout的错误?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:如何在JavaScript中处理来自setTimeout的错误?


猜你喜欢
- Flexslider 箭头未正确显示 2022-01-01
- 如何使用 JSON 格式的 jQuery AJAX 从 .cfm 页面输出查 2022-01-01
- Css:将嵌套元素定位在父元素边界之外一点 2022-09-07
- 400或500级别的HTTP响应 2022-01-01
- CSS媒体查询(最大高度)不起作用,但为什么? 2022-01-01
- addEventListener 在 IE 11 中不起作用 2022-01-01
- Quasar 2+Apollo:错误:找不到ID为默认的Apollo客户端。如果您在组件设置之外,请使用ProvideApolloClient() 2022-01-01
- 使用RSelum从网站(报纸档案)中抓取多个网页 2022-09-06
- Fetch API 如何获取响应体? 2022-01-01
- 失败的 Canvas 360 jquery 插件 2022-01-01