【JavaScript】JS 中的错误类型

JavaScript 中的错误类型

JavaScript 中的报错信息主要分为两大类:

  • 第一类是语法错误:这一类错误再预解析的过程中如果遇到,就会导致整个 JS 文件都无法执行
  • 另一类错误统称为异常:这一类的错误会导致在错误出现的那一行之后的代码无法执行,但在那一行之前的代码不会受到影响

以下为错误类型的详细介绍:

SynataxError(语法错误)

// Syntax Error: 语法错误
// 变量名不符合规范
var 1       // Uncaught SyntaxError: Unexpected number
var 1a       // Uncaught SyntaxError: Invalid or unexpected token
// 1.2 给关键字赋值
function = 5      // Uncaught SyntaxError: Invalid or unexpected token

Uncaught ReferenceError(引用错误)

引用一个不存在的变量时发生的错误。将一个值分配给无法分配的对象,比如对函数的运行结果或者函数赋值

// 引用了不存在的变量
a() // Uncaught ReferenceError: a is not defined
console.log(b) // Uncaught ReferenceError: b is not defined
// 2.2 给一个无法被赋值的对象赋值
console.log('abc') = 1 // Uncaught ReferenceError: Invalid left-hand side in assignment

RangeError(范围错误)

RangeError 是当一个只超出有效范围时发生的错误。主要的有几种情况,第一是数组长度为负数,第二是 Number 对象的方法参数超出范围,以及函数堆栈超过最大值

// 数组长度为负数
[].length = -5 // Uncaught RangeError: Invalid array length
// Number对象的方法参数超出范围
var num = new Number(12.34)
console.log(num.toFixed(-1)) // Uncaught RangeError: toFixed() digits argument must be between 0 and 20 at Number.toFixed

toFixed 方法的作用是将数字四舍五入为指定小数位数的数字,参数是小数点后的位数,范围为 0-20

TypeError(类型错误)

变量或参数不是预期类型时发生的错误。比如使用 new 字符串、布尔值等原始类型和调用对象不存在的方法就会抛出这种错误,因为 new 命令的参数应该是一个构造函数

// 调用不存在的方法
123() // Uncaught TypeError: 123 is not a function
var o = {}
o.run() // Uncaught TypeError: o.run is not a function
// new关键字后接基本类型
var p = new 456() // Uncaught TypeError: 456 is not a constructor

URIError(URL 错误)

主要是相关函数的参数不正确

decodeURI('%') // Uncaught URIError: URI malformed at decodeURI

URI 相关参数不正确时抛出的错误,主要涉及 encodeURI()decodeURI()encodeURIComponent()decodeURIComponent()escape()unescape()六个函数

EvalError(eval()函数执行错误)

ES5 以下的 JavaScript 中,当 eval()函数没有被正确执行时,会抛出 evalError 错误

var myEval = eval
myEval("alert('call eval')")

需要注意的是:ES5 以上的 JavaScript 中已经不再抛出该错误,但依然可以通过 new 关键字来自定义该类型的错误提示

总结

以上的 6 种派生错误,连同原始的 Error 对象,都是构造函数

new Error([message[,fileName[,lineNumber]]])
// 第一个参数表示错误提示信息,第二个参数表示文件名,第三个参数表示行号
posted @ 2020-05-23 15:27  [ABing]  阅读(174)  评论(0编辑  收藏  举报