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

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

反过来,这意味着ItemList将项目定义为未定义,并且您在控制台中收到错误 - “Uncaught TypeError:无法读取未定义的属性’map’”。 这很容易解决。...例如,如果您在CDN上托管JavaScript代码,任何未捕获的错误(冒泡到window.onerror处理程序的错误,而不是在try-catch中捕获)将被报告为“脚本错误”而不是包含有用的错误 信息...TypeError: Object doesn’t support property 当您调用未定义的方法时,这是在IE中发生的错误。...这相当于Chrome中的错误“TypeError:’undefined’不是函数”。 是的,不同的浏览器可以针对相同的逻辑错误具有不同的错误消息。...在这种情况下,应用程序将抛出“Uncaught TypeError无法设置未定义的属性”。 10.

11610

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

TypeError: ’undefined’ is not an object 在Safari里读取未定义对象的属性或调用未定义对象的方法时就会发生这个错误,在Safari开发者控制台可以很容易地重现这个错误...可以使用严格等于号来证明它们不是同一个东西。...TypeError: Object doesn’t support property 在IE里读取未定义对象的属性或调用未定义对象的方法时就会发生这个错误,在IE开发者控制台可以很容易地重现这个错误。...TypeError: ‘undefined’ is not a function 在Chrome里调用一个未定义函数时就会发生这个错误,可以在Chrome开发者控制台和Mozilla开发者控制台重现这个错误...如果在进行事件处理时遇到这个错误,请确保事件对象被作为参数传入到函数当中。旧浏览器(IE)提供了全局的event变量,但并不是所有的浏览器都会这样。

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

10 种最常见的 Javascript 错误

TypeError: ‘undefined’ is not an object 这是在 Safari 中读取属性或调用未定义对象上的方法时发生的错误。...TypeError: Object doesn’t support property 这是您在调用未定义的方法时发生在 IE 中的错误。 您可以在 IE 开发者控制台中进行测试。 ?...TypeError: ‘undefined’ is not a function 当您调用未定义函数时,这是 Chrome 中产生的错误。...Uncaught TypeError: Cannot set property 当我们尝试访问一个未定义的变量时,它总是返回 undefined,我们不能获取或设置任何未定义的属性。...像 IE 这样的旧浏览器提供了一个全局变量事件,但并不是所有浏览器都支持。像 jQuery 这样的库试图规范化这种行为。尽管如此,最好使用传入事件处理函数函数

6.8K80

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

TypeError: ‘undefined’ is not an object 这是在 Safari 中读取属性或调用未定义对象上的方法时发生的错误。...TypeError: ‘undefined’ is not a function 当您调用未定义函数时,这是 Chrome 中产生的错误。...TypeError: Cannot read property ‘length’ 这是 Chrome 中发生的错误,因为读取未定义变量的长度属性。...Uncaught TypeError: Cannot set property 当我们尝试访问一个未定义的变量时,它总是返回 undefined,我们不能获取或设置任何未定义的属性。...像 IE 这样的旧浏览器提供了一个全局变量事件,但并不是所有浏览器都支持。像 jQuery 这样的库试图规范化这种行为。尽管如此,最好使用传入事件处理函数函数

6.2K10

1000多个项目中的十大JavaScript错误以及如何避免

例如,如果将 JavaScript 代码托管在 CDN 上,则任何未被捕获的错误(通过 window.onerror 处理程序发出的错误,而不是 try-catch 中捕获到的错误)将仅报告为“脚本错误...TypeError: Object Doesn’t Support Property 当调用未定义的方法时,IE 中会发生这样的错误。 ?...TypeError: ‘undefined’ Is Not a Function 当调用未定义函数时,Chrome 中就会发生这样的错误。 ?...TypeError: Cannot Read Property ‘length’ 这是 Chrome 中发生的错误,因为读取了未定义长度属性的变量。 ?...Uncaught TypeError: Cannot Set Property 当尝试访问未定义的变量时,总会返回 undefined。我们也无法获取或设置 undefined 的任何属性。

8.2K40

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

调用尚未定义函数。 现在,当我们创建或定义一个没有赋值的变量时。 该变量以键作为变量名称写入环境记录,但该值将保持未定义状态。...can't find it 注意:未定义的变量不会抛出ReferenceError,因为它存在于环境记录中只是它的值尚未设置。...4.TypeError 类型错误 当其他NativeError对象中没有一个是失败原因的适当指示时,TypeError用于指示操作失败。 对错误的数据类型执行操作时会发生TypeError。...如果我们对Objects,Boolean,Symbol,null,undefined数据类型调用toUpperCase函数,则只有字符串会转换为大写或小写形式,我们将得到TypeError,因为它操作的数据类型错误..."%"不是正确的URI,因此引发了URIError。 如果对URI进行编码或解码有问题,则会引发URIError。 6.EvalErro 在使用全局eval()函数时,此函数用于识别错误。

3.9K10

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

调用尚未定义函数。 现在,当我们创建或定义一个没有赋值的变量时。变量将键作为变量名写入环境记录,但该值将保持未定义状态。...TypeError TypeError 是指对象用来表示值的类型非预期类型时发生的错误。例如,我们期望它是布尔值,但结果发现它是string类型。...TypeError: num.toUpperCase is not a function 因为toUpperCase函数需要字符串数据类型。...如果我们在Objects,Boolean,Symbol,null,undefined数据类型上调用toUpperCase函数,则只有字符串会转换为大写或小写形式,我们将得到TypeError,因为它操作的数据类型错误...“%”不是正确的URI,因此引发了URIError。 编码或解码URI时出现问题时,将引发URIError。 6. EvalError 如果非法调用 eval(),则抛出 EvalError 异常。

2.6K10

javascript中的Strict模式

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

84730

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

,这对我们来说无疑是一种挫折,在不知如何着手解决错误的时,只能反覆地检查自己的代码,看看是不是有什么奇怪的地方,有时就算停在了错误地方也往往不知是什么意思,会因此花费大量的时间。...JavaScript 开发环境中安装 ESLint ❞ ReferenceError: a is not defined ReferenceError: a is not defined 引用错误:由于变量 a 未定义...,所以在使用这个变量时会出现未定义的提示,只要先定义好这个变量即可。...Uncaught ReferenceError: $ is not defined 错误类型:TypeError TypeError 是类型上的错误,同样 IDE 也不会预先提示有错误,必须在执行时才会看到...('a') (function() { console.log('立即执行函数') })() 说明:这代码看起来是立即执行函数的错误,但是却出现了 console.log(...) is not

3K20

javascript中的Strict模式

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

86530
领券