-
常见的异常分类
运行环境的多样性导致的异常(浏览器)
语法错误,代码错误
异常的特征:一旦代码出现异常,后面的代码就不会再执行
-
异常捕获
使用try-catch语句捕获异常
try{
//这里写可能出现异常的代码
}catch(e){
//这里的e就是捕获的异常对象
//可以在这里写,出现异常后的处理代码
}
-
异常捕获语句执行的过程为:
01 代码正常运行, 如果在try中出现了错误, try 里面出现错误的语句后面的代码都不再执行, 直接跳转到 catch 中
02 在catch中处理错误信息
03 继续执行后面的代码
04 如果 try 中没有出现错误, 那么不走 catch 直接执行后面的代码
捕获异常的优点:通过try-catch语句进行异常捕获之后,代码将会继续执行,而不会中断。
****注意****:语法错误异常用try-catch语句无法捕获,因为在预解析阶段,语法错误会直接检测出来,而不会等到运行的时候才报错。-
try..catch使用示例
//01 try ... catch结构的使用
//a(); 若直接调用则爆出:Uncaught ReferenceError: a is not defined错误
//在开发中,我们对于可能会报错或者是发生异常的代码用try结构进行处理
try{
a(); //如果发生异常,那么至少不会到正程序中断
}
catch(e) {
//如果try语句中发生了异常,那么会执行此处的代码块
//参数e.为具体的异常信息,可以打印进行查看
console.log(e);
}
function functionTest() {
console.log("functionTest");
};
functionTest();
//结论:使用try...catch结构,如果发生了异常,那么不会影响后面代码的执行,且我们可以在发生异常信息之后做出具体的处理
-
手动抛出异常
语法 throw 具体的信息
抛出的内容:字符串 + 对象
自己编码规范:如果出错或者是有异常,那么就抛出一个对象(msg code)
函数未定义 1001
变量未定义 1002
访问了错误的数据 1003
案例:自己写的一个函数,需要一个参数,如果用户不传参数,此时想直接给用户抛出异常,就需要了解如何抛出异常。
- 抛出异常使用throw关键字,语法如下:
手动抛出异常信息(字符串)
try{
//a(); //如果发生异常,那么至少不会到正程序中断
//不使用系统默认的异常信息,尝试手动抛出
throw "对不起,您调用了尚未定义的方法";
}
catch(e)
{
//如果try语句中发生了异常,那么会执行此处的代码块
//参数e.为具体的异常信息,可以打印进行查看
console.log(e);
}
function functionTest() {
console.log("functionTest");
};
functionTest();
手动抛出异常信息(对象)
try{
//a(); //如果发生异常,那么至少不会到正程序中断
//不使用系统默认的异常信息,尝试手动抛出
throw {
errMsg:"具体的错误信息提示",
errCode:"指定错误类型的代号,如1001等"
};
}
catch(e)
{
//如果try语句中发生了异常,那么会执行此处的代码块
//参数e.为具体的异常信息,可以打印进行查看
console.log(e);
//在try语句中抛出的错误信息是什么,那么得到的异常信息就是什么
//如果抛出的是字符串,那么得到的就是字符串
//如果抛出的是对象,那么此处得到的就是对象
console.log(e.errMsg);
console.log(e.errCode);
}
function functionTest() {
console.log("functionTest");
};
functionTest();
异常捕获语句的完整模式
异常捕获语句的完整模式为try-catch-finally
try{
//在执行的时候可能发生异常的代码
b();
}
catch (e)
{
//如果try代码块中的代码在执行中发生了异常,那么就会执行该代码块的代码
//通过打印e对象可以查看具体的异常信息
console.log(e); //打印异常信息
}
finally {
//不论try语句中的代码是否会发生异常,都一定会执行此处的代码块
//一般在前端开发中很少使用,常用语后台开发的资源释放工作
console.log("无论如何总要执行的代码");
}
finally中的代码,不管是否发生异常,都会执行。一般用在后端语言中,用来释放资源,JavaScript中很少会用到。