首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

你必须掌握的 7 种 JavaScript 错误类型

2、 ReferenceError 引用错误 当对变量/项目的引用被破坏,将引发此错误。 那是变量/项目不存在。...当在记录中找到环境值并提取并返回值,将以该变量的名称作为关键字搜索环境记录。 调用尚未定义的函数。 现在,当我们创建或定义一个没有赋值的变量。...将在env记录中搜索该变量,当找到初始未定义,该赋值将被覆盖。...can't find it 注意:未定义的变量不会抛出ReferenceError,因为它存在于环境记录中只是它的值尚未设置。...当我们键入JS引擎可以理解的代码,会发生此错误。 解析期间,JS引擎捕获了此错误。 在JS引擎中,我们的代码经过不同的阶段,然后才能在终端上看到这些结果。

3.9K10

javaScript代码飘红报错看不懂?读完这篇文章再试试!

本文将会出现以下英语词汇 assignment[əˈsaɪnmənt] 赋值;分配 assignment [əˈsaɪnmənt] 分配;任务 call [kɔːl] 调用 caught [kɔːt] 捕获...] 范围;界限;区间; 类; 种; token [ˈtəʊkən] 令牌;标记 try [traɪ] 尝试 throw [θrəʊ] 投;掷;抛;扔;摔;丢;猛推;使劲撞 Uncaught 捕获...常见的四种Error类型 1、ReferenceError(引用错误):使用了未定义的变量。...// 1、变量未定义便直接使用 console.log(my); // 报错:Uncaught ReferenceError: my is not defined // 翻译:my未定义 // 2、将变量赋值给一个无法被赋值的东东...•使用try包裹的代码,即使不出错,效率也比不用try包裹的代码低。•在try中,尽量少的包含可能出错的代码。•无法提前预知错误类型的错误,必须用try catch捕获。•finally可以省略。

5.4K20
您找到你想要的搜索结果了吗?
是的
没有找到

你应该知道的7 个 JavaScript 原生错误类型

ReferenceError 当对变量或项目的引用被破坏,将会引发此错误。那是变量或项目不存在。...当在记录中找到环境值并提取并返回值,将以该变量的名称作为关键字在环境记录进行搜索。调用尚未定义的函数。 现在,当我们创建或定义一个没有赋值的变量。...将在环境记录中搜索该变量,当发现它未定义,该赋值将被覆盖。...can't find it 注意:未定义的变量不会抛出 ReferenceError,因为它在于环境记录中的值尚未设置。 3. SyntaxError 这是最常见的错误。...当我们输入 JS 引擎不能理解的代码,就会发生这个错误。 JS 引擎在解析期间捕获了这个错误。在 JS 引擎中,我们的代码经历了不同的阶段,然后才能在终端上看到结果。

2.6K20

JavaScript 开发中常见错误解决小总结

但是一旦出现红字幸灾乐祸的告诉我们“你出错了!”...语法解析错误:预期的符号 },代码结尾多了一个 } 符号导致环境运行错误,这个错误的排查方法与上面相同,尽可能将代码排整齐并维持首尾符号的一致。...: a is not defined 引用错误:由于变量 a 未定义,所以在使用这个变量时会出现未定义的提示,只要先定义好这个变量即可。...❝排查重点:需要重新检查逻辑,如果有必要可先删除部分代码,先找出错误的片段后再进行除错。...这类错误也很常见,却不容易找到出错的原因,其主要原因是在递归超过了环境的限制(使用框架也很常见),如果遇到这错误建议改写当前调用函数的方式。

3K20

分享30个你必须知道的JS基础知识

undefined 是未指定特定值的变量或显式返回值的函数的默认值,例如 console.log(1),以及对象中不存在的属性,JS 引擎为其分配未定义的值。...在此示例中,当 fs.readFile 方法出错误时,我们将获得一个空值。...另一方面,在“捕获阶段”期间,事件从窗口开始在元素上触发,并向下传播到事件目标或 event.target。...事件传播分为三个阶段: 捕获阶段:事件从窗口开始,然后向下传播到每个元素,直到到达目标元素。 目标阶段:事件已经到达目标元素。 冒泡阶段:事件从目标元素冒泡,然后上升到每个元素,直到到达窗口。...当一个事件发生在 DOM 元素上,它不仅仅发生在那个特定的元素上。 在捕获阶段,事件从窗口开始,一直向下传播到触发事件的元素。

19430

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

随着前端页面承载功能越来越多,用户本地浏览器环境也错综复杂,因此即使有完善的测试,我们也无法保证上线的代码不会出错。在这种场景下,前端页面的监控就成了各个web项目必备的工具。...e.g: 下图是当使用了未定义的变量"foo",导致产生js运行时错误时的上报数据: ? 2、资源加载错误 这里的静态资源包括js、css以及image等。...如果某个节点出现问题导致某个静态资源无法访问,就需要能够捕获这种异常并进行上报,方便第一间解决问题。 e.g: 下图是图片资源不存在的上报数据: ?...3、未处理的promise错误 使用catch捕获的promise错误,往往都会存在比较大的风险。而编码时有可能覆盖的不够全面,因此有必要监控未处理的promise错误并进行上报。...像axios和jQuery等库就是在xhr上的封装,而有些情况也可能会使用原生的fetch,因此对这两种情况都要进行捕获。 e.g: 下图是xhr请求接口返回400捕获后的上报数据: ?

3.6K40

7种你应该知道的JavaScript常见的错误

ReferenceError 当对变量/项的引用被破坏或不存在,将引发此错误。也就是说,变量/项不存在。...当在记录中找到环境值并提取并返回值,将以该变量的名称作为关键字搜索环境记录。调用尚未定义的函数。 现在,当我们创建或定义一个没有赋值的变量。...将在env记录中搜索该变量,当发现该初始未定义,该赋值将被覆盖。...can't find it 注意:未定义的变量不会抛出ReferenceError,因为它存在于环境记录中只是它的值尚未设置。 3. SyntaxError 这是我们遇到的最常见的错误。...当我们键入JS引擎难以理解的代码,会出现此错误。解析期间,JS引擎捕获了此错误。 在JS引擎中,我们的代码经历了不同的阶段,然后才能在终端上看到运行结果。

2.6K10

剖析前端异常及其降级处理和防范方案

image.png ReferenceError 当引用不存在的变量,该对象表示错误: ?...所以,如果你希望当前可能出错的代码块后续的代码能够正常运行的话,那么你就得使用try...catch来主动捕获异常。 扩展: 实际上,出错代码是如何干扰后续代码的执行,是一个值得探讨的主题。...特定的错误信息,比如错误所在的生命周期钩子 // 只在 2.2.0+ 可用 } 复制代码 指定组件的渲染和观察期间捕获错误的处理函数。...六、扩展 1.设置采集率 若是错误实在太多,比如有时候代码进入死循环,错误量过多导致服务器压力大,可酌情降低采集率。...那有没有办法将其作为一个配置项,配置完之后,编译自动套上一层ErrorBoundary组件呢?这个我们下次在做探讨! 3.可配置 能否将ErrorBoundary扩展成可传入自定义UI的组件呢?

1.1K40

浅析前端异常及降级处理

image.png ReferenceError 当引用不存在的变量,该对象表示错误: image.png SyntaxError 当JavaScript引擎在解析代码遇到不符合该语言语法的标记或标记顺序时...所以,如果你希望当前可能出错的代码块后续的代码能够正常运行的话,那么你就得使用try...catch来主动捕获异常。 扩展: 实际上,出错代码是如何干扰后续代码的执行,是一个值得探讨的主题。...特定的错误信息,比如错误所在的生命周期钩子 // 只在 2.2.0+ 可用 } 复制代码 指定组件的渲染和观察期间捕获错误的处理函数。...六、扩展 1.设置采集率 若是错误实在太多,比如有时候代码进入死循环,错误量过多导致服务器压力大,可酌情降低采集率。...那有没有办法将其作为一个配置项,配置完之后,编译自动套上一层ErrorBoundary组件呢?这个我们下次在做探讨! 3.可配置 能否将ErrorBoundary扩展成可传入自定义UI的组件呢?

1.4K10

【Web技术】剖析前端异常及降级处理

image.png ReferenceError 当引用不存在的变量,该对象表示错误: image.png SyntaxError 当JavaScript引擎在解析代码遇到不符合该语言语法的标记或标记顺序时...所以,如果你希望当前可能出错的代码块后续的代码能够正常运行的话,那么你就得使用try...catch来主动捕获异常。 扩展: 实际上,出错代码是如何干扰后续代码的执行,是一个值得探讨的主题。...特定的错误信息,比如错误所在的生命周期钩子 // 只在 2.2.0+ 可用 } 复制代码 指定组件的渲染和观察期间捕获错误的处理函数。...六、扩展 1.设置采集率 若是错误实在太多,比如有时候代码进入死循环,错误量过多导致服务器压力大,可酌情降低采集率。...那有没有办法将其作为一个配置项,配置完之后,编译自动套上一层ErrorBoundary组件呢?这个我们下次在做探讨! 3.可配置 能否将ErrorBoundary扩展成可传入自定义UI的组件呢?

1.3K10

21错误与异常

// 用于捕获指定语句块中的错误或异常 try { console.log(v); //调用未定义的变量 -> 报错 } catch (error) { // 用于处理try语句中的错误 /.../ error 表示try语句中出现错误的信息 console.log("改变量未定义"); } finally { // catch语句无法处理try语句中的错误或异常,执行finally语句中的内容...throw语句 人为抛出错误或异常,语法结构throw 异常或错误的表达式。其表达式允许是任意类型的内容。作用为预判断当前使用的变量、函数或对象是否存在。...当错误发生,就会抛出对应类型的错误对象。 Error是基本错误类型,其他错误类型都继承自该类型。Error类型的错误很少见,如果有也是浏览器抛出的。...ReferenceError 表示错误的原因:无效引用。 SyntaxError 表示错误的原因:eval()在解析代码的过程中发生的语法错误。

1.1K10

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

e.g: 下图是当使用了未定义的变量"foo",导致产生js运行时错误时的上报数据: 2、资源加载错误 这里的静态资源包括js、css以及image等。...如果某个节点出现问题导致某个静态资源无法访问,就需要能够捕获这种异常并进行上报,方便第一间解决问题。...e.g: 下图是图片资源不存在的上报数据: 3、未处理的promise错误 使用catch捕获的promise错误,往往都会存在比较大的风险。...e.g: 下图是xhr请求接口返回400捕获后的上报数据: 各个类型错误的捕获方式 1、window.onerror与window.addEventListener('error')捕获js运行时错误....catch(error => { // error.message, // error.stack // 抛出错误并且上报

3.1K90
领券