try/catch/finally

Posted bgwhite

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了try/catch/finally相关的知识,希望对你有一定的参考价值。

最近再看一个vue项目源码时看到其中很多地方用到了try和catch,很多地方都有用到但不知道其作用是什么,今天经过查阅整理如下:

try可以理解为代码的执行检测模块。再try中放置的代码一般会经过检测是否有异常错误。如果有会经过catch进行捕获。而finally呢?

这个东西他不管有没有报错他都会执行。

demo如下:

<p>请输入 5 和 10 之间的一个数:</p>
 
<input id="demo" type="text">
<button type="button" onclick="myFunction()">检测输入</button>
<p id="message"></p>
 
<script>
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;
    }
}
</script>

配合throw输出可以合理的打印出错误信息

以上是关于try/catch/finally的主要内容,如果未能解决你的问题,请参考以下文章

java中的“try - catch -finally”结构中的“finally”都有哪些用途

对try catch finally的理解

try{ } catch{ } finally{ }

try catch finally return

try/catch/finally

try catch finally 块里都有return