异常处理

  • 常见的异常分类

运行环境的多样性导致的异常(浏览器)
语法错误,代码错误

异常的特征:一旦代码出现异常,后面的代码就不会再执行

  • 异常捕获
    使用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中很少会用到。

你可能感兴趣的:(异常处理)