面向对象01-异常处理

2017-05-29  本文已影响0人  肉肉与马甲线的故事

异常处理:try....catch

js代码执行特点:从上向下执行,在执行的过程中如果出现了错误或者异常,那么就直接报错或抛出了异常。只要出错,那么后面的代码就不会再被执行。

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关键字,语法如下:

手动抛出异常信息(字符串)

    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中很少会用到。

上一篇下一篇

猜你喜欢

热点阅读