我们专注攀枝花网站设计 攀枝花网站制作 攀枝花网站建设
成都网站建设公司服务热线:400-028-6601

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

需要了解的JavaScript异常类型有哪些

需要了解的JavaScript 异常类型有哪些,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

创新互联主营天柱网站建设的网络公司,主营网站建设方案,重庆App定制开发,天柱h5微信小程序搭建,天柱网站营销推广欢迎天柱等地区企业咨询

无论是浏览器控制台还是 Node.js 的服务端,我们会在各种地方看到 JavaScript  异常,异常处理是编写程序必备的基础能力,在学习异常处理之前,了解 JavaScript 中的几种异常类型是非常有必要的。

Error

Error 是最基本的错误类型,其他的错误类型都继承自该类型。Error 对象主要有两个重要属性 message 和 name  分别表示错误信息和错误名称。

程序运行过程中抛出的异常一般都有具体的类型,Error 类型一般都是开发人员自己抛出的异常。

try {   throw new Error('ConardLi抛出的异常'); } catch (error) {   console.log(error); }

需要了解的JavaScript 异常类型有哪些

SyntaxError -  语法错误

语法错误也称为解析错误。语法错误在任何编程语言中都是最常见的错误类型,表示不符合编程语言的语法规范。

JavaScript 是一门解释性语言,执行一段代码时需要经历 词法分析 -> 语法分析 -> 语法树 就可以开始解释执行了:

需要了解的JavaScript 异常类型有哪些

词法分析是将字符流(char stream)转换为记号流(token stream)、语法分析阶段会将记号流(token  stream)生成抽象语法树(AST)。

在这两个阶段,如果 Javascript引擎发现了预期之外/无法抓换的 token,或者 token 顺序和预期不一致时,就会抛出  SyntaxError。

需要了解的JavaScript 异常类型有哪些

因此 SyntaxError 应该和其他类型的异常区分开,此类异常发生在  JavaScript解析/编译时,此类异常一旦发生,导致整个js文件都无法执行,而其他异常发生在代码运行时,这一类的错误会导致在错误出现的那一行之后的代码无法执行,但在那一行之前的代码不会受到影响。

TypeError - 类型错误

运行时最常见的异常,表示变量或参数不是预期类型,比如 new 关键字后面必须为构造函数、()前必须为函数。

需要了解的JavaScript 异常类型有哪些

ReferenceError -  引用错误

引用一个不存在的变量时发生的错误,每当我们创建或定义一个变量时,变量名称都会写入一个变量存储中心中。这个变量存储中心就像键值存储一样,每当我们引用变量时,它都去存储中找到  Key 并提取并返回 Value,如果我们要找的变量不在存储中,就会抛出 ReferenceError。

需要了解的JavaScript 异常类型有哪些

请注意,如果我们调用的是一个已经存在的变量的一个不存在的属性,则不会抛出  ReferenceError,因为变量本身已经在存储中了,调用它不存在的属性只会是未定义状态,也就是 undefined:

需要了解的JavaScript 异常类型有哪些

RangeError - 边界错误

表示超出有效范围时发生的异常,主要的有以下几种情况:

  • 数组长度为负数或超长

  • 数字类型的方法参数超出预定义范围

  • 函数堆栈调用超过最大值

需要了解的JavaScript 异常类型有哪些

URIError - URL 错误在调用 URI 相关的方法中 URL 无效时抛出的异常,主要包括  encodeURI、decodeURI()、encodeURIComponent()、decodeURIComponent()、escape()和unescape()几个函数:

需要了解的JavaScript 异常类型有哪些

自定义异常

另外,为了满足各种各样的业务需求,除了 JavaScript  已经给定的异常类型,我们还可以自定义一些异常类型,比如我们要根据不同的异常类型给用户不同的错误提示:

class UnAuthError extends Error { }  class ParamError extends Error { }  function controller() {   throw new UnAuthError(); }  try {   controller(); } catch (error) {   if (error instanceof UnAuthError) {     return '无权限';   }    if (error instanceof ParamError) {   return '参数错误';   }  }

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联行业资讯频道,感谢您对创新互联的支持。


网站栏目:需要了解的JavaScript异常类型有哪些
转载来源:http://shouzuofang.com/article/pjhgej.html

其他资讯