try catch finally 定义以及个人理解,很好很强大的代码,虽然没啥用

转载自: http://www.runoob.com/jsref/jsref-try-catch.html
try/catch/finally 语句用于处理代码中可能出现的错误信息。

错误可能是语法错误,通常是程序员造成的编码错误或错别字。也 可能是拼写错误或语言中缺少的功能(可能由于浏览器差异)。

try语句允许我们定义在执行时进行错误测试的代码块。

catch 语句允许我们定义当 try 代码块发生错误时,所执行的代码块。

finally 语句在 try 和 catch 之后无论有无异常都会执行。

注意: catch 和 finally 语句都是可选的,但你在使用 try 语句时必须至少使用一个。

提示: 当错误发生时, JavaScript 会停止执行,并生成一个错误信息。使用 throw 语句 来创建自定义消息(抛出异常)。如果你将 throwtrycatch一起使用,就可以控制程序输出的错误信息。

直接上代码了

语法

try {
    tryCode - 尝试执行代码块
}
catch(err) {
    catchCode - 捕获错误的代码块
} 
finally {
    finallyCode - 无论 try / catch 结果如何都会执行的代码块
}

参数值

tryCode 必须。检查是否有错误的代码块。
err 必须(如果使用 catch)。指定局部变量应用的错误。该变量可以引用 Error 对象 (包含发生的错误信息,如 "'addlert' 没有定义")。如果异常通过 throw 语句创建 ,该 变量引用了为在throw语句中指定的对象 (查看 "更多实例")
catchCode       可选。如果 try 语句发生错误执行的代码块。如果 try 语句没发生错误该代码不会执行。
finallyCode 可选。无论 try / catch 的结果如何都会执行。

例子

function myFunction() {
    var message, x;
    message = document.getElementById("message");
    message.innerHTML = "";
    x = document.getElementById("demo").value;
    try { 
        if(x == "")  throw "为空";
        if(isNaN(x)) throw "不是一个数字";
        if(x > 10)   throw "太大";
        if(x < 5)    throw "太小";
    }
    catch(err) {
        message.innerHTML = "输入的值 " + err;
    }
    finally {
        document.getElementById("demo").value = "";
    }
}

随笔

<script type="text/javascript">
            bbq();
            function bbq(){
                var adefiend  = 'bbq';
                console.log(adefiend );
            }
            try {
                console.log('我是第一个执行的'); throw "我写throw那么如果这句话出错就在err中写出我现在打的这句话,如果不写这个throw那么系统会自己在err中写出哪里错误"
                console.log('我是第二个执行的'+ adefiend );
                console.log('我是第三个执行的');
            } 
            catch(err){
                console.log(err);
                console.log('替代品')
            }
            finally {
                //如果finally中的代码也报错那代码就真的不执行了
                console.log('我不管前面怎么样我都会执行的')
            }
            //如果出现try中有地方出错就直接去catch了而不会执行下面的代码
            console.log("我是无辜的");
            
        </script>
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容