
代码:
try{
document.exitFullscreen()
}
catch(err){
console.log(123)
}
如上,如果 document 没有进入全屏,chrome 会在控制台报 error,但是不会进 catch 线。 这种报错仅仅是浏览器告知开发者的,而不能用于捕获的吗?
1 momocraft 2019-10-13 21:32:10 +08:00 你看了 exitFullscreen 的文? |
2 codeduan 2019-10-13 21:37:37 +08:00 document.exitFullscreen() 返回了一个 promise,你可以用 promise 的 catch 方法来捕获错误,或者使用 async 函数,再在 async 里使用 try catch 语句。 |
3 codeduan 2019-10-13 21:39:08 +08:00 document.exitFullscreen().catch(() => {// error handle}) 就能捕获了。 |
| td width="auto" valign="top" align="left"> |
5 godoway 2019-10-13 21:45:20 +08:00 via Android @chenliangngng 异步函数 try catch 不了,请在 promise.catch 处理或者包装成能挂起的 async 函数。 |
6 chenliangngng OP @codeduan 才看了资料 try catch 只能捕获同步的异常,意思是 try catch 去捕获的这种异步异常,是失效的? |
7 godoway 2019-10-13 22:01:04 +08:00 via Android @chenliangngng 如果是多线程异步就能很好理解了,异常发生在另外一条线程上,所以调用处无法获取异常,因为上下文不同。 |
8 codehz 2019-10-13 22:02:55 +08:00 via Android 这样,你直接在整个 try catch 块后面加一个 console.log 就知道啥意思了 在 exitFullscreen 后面也加一个( |
9 imyxz 2019-10-14 08:35:10 +08:00 via Android @chenliangngng 你可以改造外面这个函数为 async 函数,调用的时候变成 await document.exitFullScreen(),一样可以用 try catch。。。 |
10 rioshikelong121 2019-10-14 12:29:01 +08:00 摸鱼居然学习到了新知识, |