首页
学习
活动
专区
圈层
工具
发布

面试官:用一句话描述 JS 异常是否能被 try catch 捕获到 ?

欢笑交谈中,拿到 offer ………… ---- 我们我们来分析下这个一句话描述 try catch 的含义。 主要分为三段:try catch 之前,之中,之后。...比如语法异常(syntaxError),因为语法异常是在语法检查阶段就报错了,线程执行尚未进入 try catch 代码块,自然就无法捕获到异常。...如果是在之前,或者之后,都无法捕捉异常。 敲黑板:不要死记硬背,啥可以捕获,啥不能捕获!记住这一句话,永远不会忘! Promise 没异常 相对于外部 try catch,Promise 没有异常!...核心原因是因为 Promise 在执行回调中都用 try catch 包裹起来了,其中所有的异常都被内部捕获到了,并未往上抛异常。...,那么这里的 Promise 为啥能捕获到异常呢?

1.4K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    一篇文章教你如何捕获前端错误

    常见错误的分类 对于用户在访问页面时发生的错误,主要包括以下几个类型: 1、js运行时错误 JavaScript代码在用户浏览器中执行时,由于一些边界情况、本地环境的不可控等因素,可能会存在js运行时错误...如果某个节点出现问题导致某个静态资源无法访问,就需要能够捕获这种异常并进行上报,方便第一时间解决问题。 e.g: 下图是图片资源不存在时的上报数据: ?...3、未处理的promise错误 未使用catch捕获的promise错误,往往都会存在比较大的风险。而编码时有可能覆盖的不够全面,因此有必要监控未处理的promise错误并进行上报。...('error', event => (){ // 处理错误信息 }, false); // true代表在捕获阶段调用,false代表在冒泡阶段捕获。...", "", 0, 0, undefined (滑动查看) 可见 try catch 中的 Console 语句输出了完整的信息,但 window.onerror 中只能捕获“Script error”

    5.4K40

    try..catch 不能捕获的错误有哪些?注意事项又有哪些?

    JS 代码,例如try块中的以下代码在语法上是错误的,但它不会被catch块捕获。..."); } ➤ ⓧ Uncaught SyntaxError: Invalid or unexpected token 1.2.2 try..catch 与 异步代码 同样,try..catch无法捕获在异步代码中引发的异常...noSuchVariable; // undefined variable }, 1000); } catch (err) { console.log("这里不会被执行"); } 未捕获的...Error: Error while executing the code 这里注意两件事: 即使从try块抛出错误后,也会执行finally块 如果没有catch块,错误将不能被优雅地处理,从而导致未捕获的错误...2.1 Promise 中的 then..catch 我们可以使用then()和catch()链接多个 Promises,以处理链中单个 Promise 的错误,如下所示: Promise.resolve

    4.1K20

    如何及时发现网页的隐形错误

    接下来这篇文章我们就来详细学习一下前端监控系统中的,异常监控。 想要进行异常监控之前,肯定先要了解有哪些异常才能进行监控。...ReferenceError: 引用了未定义的变量或对象 TypeError: 类型错误 URIError: URI操作错误 SyntaxError: 语法错误 (这个错误WebIDL中故意省略,保留给...通过创建实例的方式,例如 new Image()等代码来实现初始化。 那既然我们已经知道了我们的网站在客户端运行时可能会出现这些异常。那我们要如何进行捕获错误信息呢?...,而 try-catch 则是用于在可预见的情况下监控特定的错误。...,只能捕获到 Promise 对象本身的异常 无法捕获到其他异步操作中的错误,例如网络请求失败等。

    1K00

    一文详聊前端异常原理

    SyntaxError 在引擎执行代码之前,编译器需要对 js 进行编译,编辑阶段包括:词法分析,语法分析;如图: 编译阶段发生的异常都是 SyntaxError,但 SyntaxError 不完全都发生于编译阶段...因为在变量还没有声明的情况下,这两种查询的行为是不一样的。 如果 RHS 查询在所有嵌套的作用域中遍寻不到所需的变量,引擎就会抛出 ReferenceError。...React 在 ErrorDecoder 模块中对自定义错误做了介绍。...parentheses in regular expression”(正则表达式中括号过多); “array initializer too large”(数组初始化器过大); EvalError 在...来捕获接口状态 总结 本文详细讲解了 ECMA 中 8 种异常的产生原理,涉及了 LHS&RHS、递归优化、ScriptError、finally、Promise 等知识点,希望在处理异常的工作中能给你带来帮助

    2.7K40

    前端开发,如何优雅处理前端异常?

    无法捕获语法错误; 到这里基本就清晰了:在实际的使用过程中,onerror 主要是来捕获预料之外的错误,而 try-catch 则是用来在可预见情况下监控特定的错误,两者结合使用更加高效。...这些 error 事件不会向上冒泡到 window ,不过(至少在 Firefox 中)能被单一的window.addEventListener 捕获。...六、Promise Catch 在 promise 中使用 catch 可以非常方便的捕获到异步 error ,这个很简单。...没有写 catch 的 Promise 中抛出的错误无法被 onerror 或 try-catch 捕获到,所以我们务必要在 Promise 中不要忘记写 catch 处理抛出的异常。...实际上,大多数情况下我们可以在整个程序中定义一个 error boundary 组件,之后就可以一直使用它了!

    1.4K10

    如何优雅处理前端异常?

    无法捕获语法错误; 到这里基本就清晰了:在实际的使用过程中,onerror 主要是来捕获预料之外的错误,而 try-catch 则是用来在可预见情况下监控特定的错误,两者结合使用更加高效。...这些 error 事件不会向上冒泡到 window ,不过(至少在 Firefox 中)能被单一的window.addEventListener 捕获。...Promise Catch 在 promise 中使用 catch 可以非常方便的捕获到异步 error ,这个很简单。...没有写 catch 的 Promise 中抛出的错误无法被 onerror 或 try-catch 捕获到,所以我们务必要在 Promise 中不要忘记写 catch 处理抛出的异常。...实际上,大多数情况下我们可以在整个程序中定义一个 error boundary 组件,之后就可以一直使用它了!

    2.1K20

    如何优雅处理前端异常?

    无法捕获语法错误; 到这里基本就清晰了:在实际的使用过程中,onerror 主要是来捕获预料之外的错误,而 try-catch 则是用来在可预见情况下监控特定的错误,两者结合使用更加高效。...这些 error 事件不会向上冒泡到 window ,不过(至少在 Firefox 中)能被单一的window.addEventListener 捕获。...六、Promise Catch 在 promise 中使用 catch 可以非常方便的捕获到异步 error ,这个很简单。...没有写 catch 的 Promise 中抛出的错误无法被 onerror 或 try-catch 捕获到,所以我们务必要在 Promise 中不要忘记写 catch 处理抛出的异常。...实际上,大多数情况下我们可以在整个程序中定义一个 error boundary 组件,之后就可以一直使用它了!

    2.6K30

    如何优雅处理前端异常?(史上最全前端异常处理方案)

    无法捕获语法错误; 到这里基本就清晰了:在实际的使用过程中,onerror 主要是来捕获预料之外的错误,而 try-catch 则是用来在可预见情况下监控特定的错误,两者结合使用更加高效。...这些 error 事件不会向上冒泡到 window ,不过(至少在 Firefox 中)能被单一的window.addEventListener 捕获。...六、Promise Catch 在 promise 中使用 catch 可以非常方便的捕获到异步 error ,这个很简单。...没有写 catch 的 Promise 中抛出的错误无法被 onerror 或 try-catch 捕获到,所以我们务必要在 Promise 中不要忘记写 catch 处理抛出的异常。...实际上,大多数情况下我们可以在整个程序中定义一个 error boundary 组件,之后就可以一直使用它了!

    4.9K10

    Promise 对象一网打尽

    ) }); // ok 上面代码中,Promise 在resolve语句后面,再抛出错误,不会被捕获,等于没有抛出。...不过,Node.js 有一个unhandledRejection事件,专门监听未捕获的reject错误,上面的脚本会触发这个事件的监听函数,可以在监听函数里面抛出错误。...如果 Promise 内部有未捕获的错误,会直接终止进程,并且进程的退出码不为 0。 再看下面的例子。...到了那个时候,Promise 的运行已经结束了,所以这个错误是在 Promise 函数体外抛出的,会冒泡到最外层,成了未捕获的错误。...: x is not defined] // carry on [ReferenceError: y is not defined] 上面代码中,第二个catch()方法用来捕获前一个catch()方法抛出的错误

    1.2K10

    前端基础进阶(十五):详解 Promise对象

    ) }); // ok 上面代码中,Promise 在resolve语句后面,再抛出错误,不会被捕获,等于没有抛出。...不过,Node.js 有一个unhandledRejection事件,专门监听未捕获的reject错误,上面的脚本会触发这个事件的监听函数,可以在监听函数里面抛出错误。...如果 Promise 内部有未捕获的错误,会直接终止进程,并且进程的退出码不为 0。 再看下面的例子。...到了那个时候,Promise 的运行已经结束了,所以这个错误是在 Promise 函数体外抛出的,会冒泡到最外层,成了未捕获的错误。...: x is not defined] // carry on [ReferenceError: y is not defined] 上面代码中,第二个catch()方法用来捕获前一个catch()方法抛出的错误

    78820
    领券