美文网首页
面向对象01-异常处理

面向对象01-异常处理

作者: 肉肉与马甲线的故事 | 来源:发表于2017-05-29 12:14 被阅读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中很少会用到。

    相关文章

      网友评论

          本文标题:面向对象01-异常处理

          本文链接:https://www.haomeiwen.com/subject/ikvkfxtx.html