主进程中发生javascript错误_你知道 JavaScript 中的错误对象有哪些类型吗?

每当 JavaScript 中发生任何运行时错误时,都会引发Error对象。在许多情况下,我们还可以扩展这些标准Error对象,以创建我们自己的自定义Error对象。

属性

Error 对象具有2个属性

name ——设置或返回错误名称。具体来说,它返回错误所属的构造函数的名称。

它有6个不同的值-EvalError,RangeError,ReferenceError,TypeError,SyntaxError,URIError。我们将在本文后面讨论这些内容,这些所有错误类型均继承自Object-> Error-> RangeError。

message-设置或返回错误消息

f484bcc9d5b3b240e9918e3e616ade45.png

事例

1.通用的错误

我们可以使用Error对象创建一个新的Error,然后使用throw关键字显式抛出该错误。

5248cc2274d824d20bbbfc2804e8cadf.png

2.处理特定的错误类型

我们还可以使用如下的instanceof关键字来处理特定的错误类型。

17730f3fe81d3d7823055e964c1531d6.png

3.自定义错误类型

我们还可以通过创建继承Error对象的类来定义自己的错误类型。

9a872846146e4024e55d6f45a3d0f6f0.png

浏览器兼容性

afec6b138945e89792981e27873c1d63.png

Error 的对象类型

现在让我们讨论可用于处理不同错误的不同错误对象类型。

1. EvalError

创建一个error实例,表示错误的原因:与 eval() 有关。

这里要注意的一点是,当前ECMAScript规范不支持它,并且运行时不会将其抛出。取而代之的是,我们可以使用SyntaxError错误。但是,它仍然可以与ECMAScript的早期版本向后兼容。

语法

new EvalError([message[, fileName[, lineNumber]]])

事例

fce6b3b6c44f249e703bc9256c496d80.png

浏览器兼容性

ea9d275af2b3332853bc5f1f77a4105a.png
2. RangeError

创建一个error实例,表示错误的原因:数值变量或参数超出其有效范围。

new RangeError([message[, fileName[, lineNumber]]])

下面的情况会触发该错误:

1)根据String.prototype.normalize(),我们传递了一个不允许的字符串值。

// Uncaught RangeError: The normalization form should be one of NFC, NFD, NFKC, NFKDString.prototype.normalize(“-1”)

2)使用Array构造函数创建非法长度的数组

// RangeError: Invalid array lengthvar arr = new Array(-1);

3)诸如 Number.prototype.toExponential(),Number.prototype.toFixed()或Number.prototype.toPrecision()之类的数字方法会接收无效值。

40ea6db58a549ead786075e3f358bc03.png

事例

对于数值

70ffb74bb836ebf6fa6f47cf72ab2589.png

对于非数值

5caba12628605471688f93c509f1932a.png

浏览器兼容性

c9b2ea327986efa2b7e9a4c08ac3f5f7.png
3. ReferenceError

创建一个error实例,表示错误的原因:无效引用。

new ReferenceError([message[, fileName[, lineNumber]]])

事例

ReferenceError被自动触发。

08539aef02dd15abf169fe89e2062993.png

显式抛出ReferenceError

53e184e5dadfa13efd48ffa5f8f8007a.png

浏览器兼容性

760a491126ccfd261724a07118cbc960.png
4. SyntaxError

创建一个error实例,表示错误的原因:eval()在解析代码的过程中发生的语法错误。

换句话说,当 JS 引擎在解析代码时遇到不符合语言语法的令牌或令牌顺序时,将抛出SyntaxError。

捕获语法错误

2555ef57bf9851abf3ef3d2bbc246c85.png

创建一个SyntaxError

3aa48420661398944de1d7f1a992291b.png

浏览器兼容性

d09065d9b5eb51d8767f1933c0e60c36.png
5. TypeError

创建一个error实例,表示错误的原因:变量或参数不属于有效类型。

new TypeError([message[, fileName[, lineNumber]]])

下面情况会引发 TypeError:

  • 在传递和预期的函数的参数或操作数之间存在类型不兼容。
  • 试图更新无法更改的值。
  • 值使用不当。

例如:

d1f7dc8056ba0ce84a3b982bb36c274d.png

捕获TypeError

6a0ede0c6f4cbe2f4ef2e8e4b4c85aac.png

创建 TypeError

80d36c3b3469464a745e9c6e5faaaa34.png

浏览器兼容性

95e2826e96bd69740ff63a9db2237dbf.png
6. URIError

创建一个error实例,表示错误的原因:给 encodeURI()或 decodeURl()传递的参数无效。

如果未正确使用全局URI处理功能,则会发生这种情况。

c112b2a20943b2f6380febd96c257da1.png

简单来说,当我们将不正确的参数传递给encodeURIComponent()或decodeURIComponent()函数时,就会引发这种情况。

new URIError([message[, fileName[, lineNumber]]])

encodeURIComponent()通过用表示字符的UTF-8编码的一个,两个,三个或四个转义序列替换某些字符的每个实例来对URI进行编码。

// "https%3A%2F%2Fmedium.com%2F"encodeURIComponent('https://medium.com/');

decodeURIComponent()——对之前由encodeURIComponent创建的统一资源标识符(Uniform Resource Identifier, URI)组件进行解码。

// https://medium.com/decodeURIComponent("https%3A%2F%2Fmedium.com%2F")

捕捉URIError

9a334879e2aaebcc71d03661ddaf82a1.png

显式抛出URIError

834a7213a0475d861f0fec3358b1ab84.png

浏览器兼容性

05fddfc952cd07c039f9117e759095e0.png

作者:Isha Jauhari 译者:前端小智 来源:dottoro原文:http://help.dottoro.com/ljfhismo.php


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值