@(javascript)[JavaScript错误处理] [toc]javascript
做为一个程序员,须要的不单单是技术,更是须要在遇到错误的时候对错误的处理能力。就前端而言,技术一直在更新,可是JavaScript中的错误也就是那么几个。掌握不一样的报错信息会让你的实际开发事半功倍。前端
Error
是最基本的错误类型,其余的错误类型都继承自该类型。所以,全部错误的类型共享了一组相同的属性。
这个类型的错误不多见。通常使用开发人员自定义抛出的错误。java
这个错误会在使用eval()
函数发生异常时候抛出。两种状况会出错:程序员
eval
函数,而是new或者是从新赋值 这个错误基本上不会遇到,由于eval
函数原本用的就很少。不过须要注意的是,eval
是一个关键字。这个错误会在数值超出相应范围时触发
。好比使用new Array()
的时候传递一个负数或者是超过数组最大长度(4,294,967,295)的数,好比Number.MAX_VALUE,Number.MIN_VALUE。注意递归爆炸也有这个错误。数组
这个错误通常就是出如今变量找不到的状况
,好比:函数
var a = b;
Uncaught ReferenceError: b is not defined
复制代码
这时候就须要检查一下一个变量了ui
当Javascript语言解析代码时,Javascript引擎发现了不符合语法规范的tokens或token顺序时抛出SyntaxError。spa
这个错误在JavaScript中是常常遇到的,无论是初学者仍是老手。在变量中保存着之外的类型时,或者在访问不存在的方法时。都会致使这种错误。可是归根结底仍是因为在执行特定于类型的操做时,变量的类型并不符合要求所致
。好比:code
var o = new 10;
a.style.widht = "10px";
复制代码
关于设置样式这个东西,新手会遇到不少,通常这都是由获取不到元素致使的。继承
在使用encodeURI
或者decodeURI
由于URL格式不正确时,就会致使URIError错误。这种错误也不多见。
try-catch是一个错误处理的方法。使用法法是:
try {
// 尝试执行的代码
} catch(error) {
// 若是上市执行的代码不成功则执行这段代码
}
复制代码
代码中 catch
语句的error
不能省略。 在本身不能把我是否会出错的地方使用try-catch
语句能让代码运行的更舒服。try-catch
语句其实还有一句finally
语句:
try {
// 尝试执行的代码
} catch(error) {
// 若是上市执行的代码不成功则执行这段代码
} finally {
// finally的语句始终都会执行
}
复制代码
由于finally语句使用会执行,因此咱们通常都不会使用 finally
语句。
在使用try-catch
语句时发生错误咱们能够执行其余事情或者是抛出这个错误。抛出错误使用throw
操做符。
try {
alert(a)
} catch(error){
throw new Error("a is not defined")
}
复制代码
上面的代码就会抛出一个通常的错误:Uncaught Error: a is not defined
。具体抛出什么错误根据实际状况肯定。类型就是上面的那几种错误类型。