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

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

从浏览器的控制台到运行Node.js的计算机终端,我们到处都会看到各类错误。 这篇文章的重点是概述我们在JS开发过程中可能遇到的错误类型。 1....TypeError TypeError 是指对象用来表示值的类型非预期类型时发生的错误。例如,我们期望它是布尔值,但结果发现它是string类型。...toUpperCase函数是有意通用的;它不需要其this值是String对象。因此,可以将其转移到其他种类的对象中用作方法。...decodeURI("%") ^ URIError: URI malformed encodeURI,获取URI的未编码版本。“%”不是正确的URI,因此引发了URIError。...根据EcmaSpec 2018版: 此异常不再会被JavaScript抛出,但是EvalError对象仍然保持兼容性。 7.

2.6K10

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

从浏览器控制台到运行Node.js的计算机终端,我们到处都会看到错误。 这篇文章重点介绍了在JS开发过程中可能遇到的 7 种错误类型。...4.TypeError 类型错误 当其他NativeError对象中没有一个是失败原因的适当指示时,TypeError用于指示操作失败。 对错误的数据类型执行操作时会发生TypeError。...toUpperCase函数是有意通用的; 它不需要其this值为String对象。 因此,可以将其转移到其他类型的对象中用作方法。..."%"不是正确的URI,因此引发了URIError。 如果对URI进行编码或解码有问题,则会引发URIError。 6.EvalErro 在使用全局eval()函数时,此函数用于识别错误。...根据EcmaSpec 2018版: 此规范当前未使用此异常。 保留该对象是为了与本规范的先前版本兼容。

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

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

    而依赖客户端的某些方法,由于兼容性或者网络等问题,也有概率会出现运行时错误。 e.g: 下图是当使用了未定义的变量"foo",导致产生js运行时错误时的上报数据: ?...3、未处理的promise错误 未使用catch捕获的promise错误,往往都会存在比较大的风险。而编码时有可能覆盖的不够全面,因此有必要监控未处理的promise错误并进行上报。...另外在安卓4.4及以下版本的webview中,xhr对象也不存在responseURL属性。 因此我们需要额外的改写xhr的open方法,将传入的url记录下来,方便上报时带上。...当网站请求并执行一个托管在第三方域名下的脚本时,就可能遇到该错误。最常见的情形是使用 CDN 托管 JS 资源。 其实这并不是一个 JavaScript Bug。...根据这个特点,可以在 catch 语句中手动上报捕获的异常。 总结 上述的错误捕获基本覆盖了前端监控所需的错误场景,但是第三部分指出的两个其他问题,目前解决的方式都不太完美。

    3.8K40

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

    e.g: 下图是当使用了未定义的变量"foo",导致产生js运行时错误时的上报数据: 2、资源加载错误 这里的静态资源包括js、css以及image等。...e.g: 下图是图片资源不存在时的上报数据: 3、未处理的promise错误 未使用catch捕获的promise错误,往往都会存在比较大的风险。...而编码时有可能覆盖的不够全面,因此有必要监控未处理的promise错误并进行上报。...另外在安卓4.4及以下版本的webview中,xhr对象也不存在responseURL属性。 因此我们需要额外的改写xhr的open方法,将传入的url记录下来,方便上报时带上。...当网站请求并执行一个托管在第三方域名下的脚本时,就可能遇到该错误。最常见的情形是使用 CDN 托管 JS 资源。 其实这并不是一个 JavaScript Bug。

    3.3K90

    JavaScrip最容易犯的十大错误及其避免方法()

    Uncaught TypeError: Cannot read property 如果你是一个javascript开发者,你肯定看到过此错误 读取属性或调用方法的对象的未定义 这可能由于许多原因而发生,...这是因为对于空白的对象引用,DOM API返回null。 任何执行和处理DOM元素的JS代码都应该在创建DOM元素之后执行。 JS代码按照HTML中的布局从上到下进行解释。...这相当于Chrome中的错误“TypeError:’undefined’不是函数”。 是的,不同的浏览器可以针对相同的逻辑错误具有不同的错误消息。...在这种情况下,应用程序将抛出“Uncaught TypeError无法设置未定义的属性”。 10....即使没有Typescript,在使用它们之前使用guard子句来检查对象是否未定义也是有帮助的。

    18910

    一文详聊前端异常原理

    :内部异常 TypeError: 类型异常 EvalError: Eval 方法异常 URIError: URI 相关方法产生的异常 1....Android,第二个是在 iOS 下,异常对象的 message 有着兼容性的差别。...TypeError TypeError 在对值进行不合理操作时会发生,比如试图对一个非函数类型的值进行函数调用,或者引用 null 或 undefined 类型的值中的属性,那么引擎会抛出这种类型的异常...,普通递归创建 stack 累积而后计算收缩,尾递归只会占用恒量的内存。...当编译器检测到一个函数调用是尾递归的时候,它就覆盖当前的活动记录而不是在栈中去创建一个新的。 5. Error 与自定义异常 Error 是所有错误的基类,其他错误类型继承该类型。

    1.5K40

    javascript中的Strict模式

    比如可以使用未定义的变量,可以给对象中的任意属性赋值并不会抛出异常等等。 在ES5中,引入了strict模式,我们可以称之为严格模式。相应的sloppy mode就可以被称为非严格模式。...严格模式并不是非严格模式的一个子集,相反的严格模式在语义上和非严格模式都发生了一定的变化,所以我们在使用过程中,一定要经过严格的测试。以保证在严格模式下程序的执行和非严格模式下的执行效果一致。...强制抛出异常 在js中,有很多情况下本来可能是错误的操作,但是因为语言特性的原因,并没有抛出异常,从而导致最终运行结果并不是所期待的。 如果使用strict模式,则会直接抛出异常。....x = 5; // throws a TypeError // 赋值给一个禁止扩展的对象 var fixed = {}; Object.preventExtensions(fixed); fixed.newProp...; // throws a TypeError 禁止对象和函数参数中的重复属性: 'use strict'; var o = { p: 1, p: 2 }; // Duplicate declaration

    91330

    从ECMAscript标准文档看懂valueOf

    翻译过来就是: 参数类型 返回结果 Undefined 抛出 TypeError 异常 Null 抛出 TypeError 异常 Boolean 创建一个Boolean对象,初始值为参数值 Number...既然我们都知道js完全可以通过使用 call 和 apply 来改变this指向,那么也就是说完全这些方法可以被任意类型的值使用,那么此时的返回值又是什么呢?...查询文档,可以看到规范对于 Internal slots 的说明: ? 大致意思是说 internal slots 不是对象的属性,不会被继承,初始值都是未定义的。...而 Boolean 、Number、String、Symbol、Date对象的原型则重写了 valueOf 方法,且传入不是该类型的参数参数时会报错,列表为: Object.prototype.valueOf...参数类型 返回结果 Undefined 抛出 TypeError 异常 Null 抛出 TypeError 异常 Boolean 创建一个Boolean对象,初始值为参数值 Number 创建一个Number

    80410

    javascript中的Strict模式

    比如可以使用未定义的变量,可以给对象中的任意属性赋值并不会抛出异常等等。 在ES5中,引入了strict模式,我们可以称之为严格模式。相应的sloppy mode就可以被称为非严格模式。...严格模式并不是非严格模式的一个子集,相反的严格模式在语义上和非严格模式都发生了一定的变化,所以我们在使用过程中,一定要经过严格的测试。以保证在严格模式下程序的执行和非严格模式下的执行效果一致。...强制抛出异常 在js中,有很多情况下本来可能是错误的操作,但是因为语言特性的原因,并没有抛出异常,从而导致最终运行结果并不是所期待的。 如果使用strict模式,则会直接抛出异常。....x = 5; // throws a TypeError // 赋值给一个禁止扩展的对象 var fixed = {}; Object.preventExtensions(fixed); fixed.newProp...; // throws a TypeError 禁止对象和函数参数中的重复属性: 'use strict'; var o = { p: 1, p: 2 }; // Duplicate declaration

    86830

    JS 常见报错及异常处理办法总结

    至此,本文主要记录js 常见的一些错误类型,以及常见的报错信息,分析其报错原因,并给予处理方法。并且将介绍几种捕获异常的方法。...访问或设置未定义(undefined)或null值的属性时会发生这种报错。...let obj = undefined console.log(obj&&obj.id) 7、TypeError: 'x' is not a constructor 含义:表示 ‘x’不是构造函数 为什么报错...使用不是构造器的对象或者变量来作为构造器使用。 比如:new 10。 举个栗子 let Car = 1; new Car(); new Math(); 处理办法 使用正确的构造函数。...createXHR('http://192.168.10:8080') 异常调试及捕获 try/catch,Js中处理异常的一种模式,try用于可能会发生错误的代码,catch对错误的处理。

    8.7K20

    JS常见的报错及异常捕获

    至此,本文主要记录Js 常见的一些错误类型,以及常见的报错信息,分析其报错原因,并给予处理方法。并且将介绍几种捕获异常的方法。 注:本文使用的谷歌游览器验证,不同的游览器,报错可能会不一样。...访问或设置未定义(undefined)或null值的属性时会发生这种报错。...let obj = undefined console.log(obj&&obj.id) ---- TypeError: 'x' is not a constructor 含义:表示 ‘x’不是构造函数...使用不是构造器的对象或者变量来作为构造器使用。比如:new 10。 举个栗子 → let Car = 1; new Car(); new Math(); 处理办法 使用正确的构造函数。...createXHR('http://192.168.10:8080') 异常调试及捕获 ---- try/catch,Js中处理异常的一种模式,try用于可能会发生错误的代码,catch对错误的处理

    5.8K30

    10 种 JavaScript 最常见的错误

    当你读取一个未定义的对象的属性或调用其方法时,这个错误会在 Chrome 中出现。 您可以很容易的在 Chrome 开发者控制台中进行测试。 ?...2、 TypeError: ‘undefined’ is not an object 这是在 Safari 中读取属性或调用未定义对象上的方法时发生的错误。...3、 TypeError: null is not an object 这是在 Safari 中读取属性或调用空对象上的方法时发生的错误。...5、 TypeError: Object doesn’t support property 这是您在调用未定义的方法时发生在 IE 中的错误。 您可以在 IE 开发者控制台中进行测试。 ?...如果在使用 event 时遇到此错误,请确保使用传入的事件对象作为参数。像 IE 这样的旧浏览器提供了一个全局变量事件,但并不是所有浏览器都支持。

    8.6K20

    JavaScript 编程精解 中文第三版 八、Bug 和错误

    其他的东西,比如调用不是函数的东西,或者在未定义的值上查找属性,会导致在程序尝试执行操作时报告错误。...不过,JavaScript 在处理无意义的计算时,会仅仅返回NaN(表示不是数字)或undefined这样的结果。...通常,代码与外部交互的对象越多,建立用于测试它的上下文就越困难。 上一章中显示的编程风格,使用自包含的持久值而不是更改对象,通常很容易测试。...我们将在第 20 章中讨论的,无浏览器的 JavaScript 环境 Node.js 对数据损坏更加谨慎。 当发生未处理的异常时,它会中止整个过程。 对于程序员的错误,让错误通行通常是最好的。...对于在日常使用中发生的预期问题,因未处理的异常而崩溃是一种糟糕的策略。 语言的非法使用方式,比如引用一个不存在的绑定,在null中查询属性,或调用的对象不是函数最终都会引发异常。

    1.2K100

    10 种最常见的 Javascript 错误

    当你读取一个未定义的对象的属性或调用其方法时,这个错误会在 Chrome 中出现。 您可以很容易的在 Chrome 开发者控制台中进行测试(尝试)。 ?...TypeError: ‘undefined’ is not an object 这是在 Safari 中读取属性或调用未定义对象上的方法时发生的错误。...TypeError: null is not an object 这是在 Safari 中读取属性或调用空对象上的方法时发生的错误。...Uncaught TypeError: Cannot set property 当我们尝试访问一个未定义的变量时,它总是返回 undefined,我们不能获取或设置任何未定义的属性。...如果在使用事件处理系统时遇到此错误,请确保使用传入的事件对象作为参数。像 IE 这样的旧浏览器提供了一个全局变量事件,但并不是所有浏览器都支持。像 jQuery 这样的库试图规范化这种行为。

    6.8K80

    1000个项目中前10名的JavaScript错误介绍

    当你读取一个未定义的对象的属性或调用其方法时,这个错误会在 Chrome 中出现。 您可以很容易的在 Chrome 开发者控制台中进行测试(尝试)。...TypeError: ‘undefined’ is not an object 这是在 Safari 中读取属性或调用未定义对象上的方法时发生的错误。...TypeError: null is not an object 这是在 Safari 中读取属性或调用空对象上的方法时发生的错误。...因为 DOM API 对于空白的对象引用返回值为 null。 任何执行和处理 DOM 元素的 JS 代码都应该在创建 DOM 元素之后执行。 JS 代码按照 HTML 中的规定从上到下进行解释。...如果在使用事件处理系统时遇到此错误,请确保使用传入的事件对象作为参数。像 IE 这样的旧浏览器提供了一个全局变量事件,但并不是所有浏览器都支持。像 jQuery 这样的库试图规范化这种行为。

    6.2K10

    JavaScript中错误正确处理方式,你用对了吗?

    Demo演示 本文中使用的demo可以在GitHub上找到,运行之后会是这样的页面: 每个按钮都会引发一个“错误(Exception)”,同时这个错误会模拟出一个被抛出的异常TypeError。...(error, TypeError); }); 这个单元测试在Mocha中,同时在 Should.js中有测试声明。...因为bar( )在对象内不存在,所以就会引发异常。这种发生在像JavaScript这样的动态语言上的错误,每个人可能都会遇到!...有了这个改进,以上的处理不再是较差的处理方式了,而是一个清晰有用的方式。 经过了上面的处理,我们还收到了一个未处理的异常。接下来让我们看看浏览器在处理错误时,有什么帮助。...虽然堆栈属性不是标准的一部分,但是最新的浏览器已经可以查看这些信息了。

    64810

    来自1000多个项目的10大JavaScript错误浅析

    在Chrome里读取未定义对象的属性或调用未定义对象的方法时就会发生这个错误,在Chrome开发者控制台可以很容易地重现这个错误。...TypeError: ’undefined’ is not an object 在Safari里读取未定义对象的属性或调用未定义对象的方法时就会发生这个错误,在Safari开发者控制台可以很容易地重现这个错误...TypeError: Object doesn’t support property 在IE里读取未定义对象的属性或调用未定义对象的方法时就会发生这个错误,在IE开发者控制台可以很容易地重现这个错误。...例如,在Chrome中: 如果test对象不存在,就会抛出“Uncaught TypeError: cannot set property of undefined”异常。 10....如果在进行事件处理时遇到这个错误,请确保事件对象被作为参数传入到函数当中。旧浏览器(IE)提供了全局的event变量,但并不是所有的浏览器都会这样。

    6.2K80
    领券