定义以及用法:javascript
try/catch/finally 语句用于处理代码中可能出现的错误信息。html
错误多是语法错误,一般是程序员形成的编码错误或错别字。也多是拼写错误或语言中缺乏的功能(可能因为浏览器差别)。java
try语句容许咱们定义在执行时进行错误测试的代码块。程序员
catch 语句容许咱们定义当 try 代码块发生错误时,所执行的代码块。编程
finally 语句在 try 和 catch 以后不管有无异常都会执行。浏览器
注意: catch 和 finally 语句都是可选的,但你在使用 try 语句时必须至少使用一个。编程语言
提示: 当错误发生时, JavaScript 会中止执行,并生成一个错误信息。使用 throw 语句 来建立自定义消息(抛出异常)。若是你将 throw 和 try 、 catch一块儿使用,就能够控制程序输出的错误信息。函数
总结:测试
try { //执行的代码,其中可能有异常。一旦发现异常,则当即跳到catch执行。不然不会执行catch里面的内容 }
catch { //除非try里面执行代码发生了异常,不然这里的代码不会执行 }
finally { //无论什么状况都会执行,包括try catch 里面用了return ,能够理解为只要执行了try或者catch,就必定会执行 finally } 编码
案例:
(function (){ try{ throw new Error(); }catch(x){ var x = 1, y = 2; console.log(x); // 1 } console.log(x); //undefined console.log(y); //2 }());
下面说一下js错误Error对象的详解:
一·概念
error,指程序中的非正常运行状态,在其余编程语言中称为“异常”或“错误”。解释器会为每一个错误情形建立并抛出一个Error对象,其中包含错误的描述信息。
ECMAScript定义了六种类型的错误。除此以外,还可使用Error构造方法建立自定义的Error对象,并使用throw语句抛出该对象。
六种错误:
二·错误处理
即便程序发生错误,也保证不异常中断的机制。
try{ 可能发生错误的代码 }catch(err){ 只有发生错误时才执行的代码 }finally{ 不管是否出错,确定都要执行的代码 }
什么时候:若是函数的定义者,须要告知调用者使用过程当中的错误;
如何:throw new Error("提示文字");
// 甲:定义函数的人 function round(num, d){ if(!isNaN(num) && !isNaN(d)){ num *= Math.pow(10, d); return num; }else{ // 抛出自定义错误 throw new Error("参数必须是数字"); } } // 乙:调用函数的人 var d = parseInt(prompt('请输入数字')); try{ alert(round(123.456, d)); }catch(err){ alert(err.message); // 接住抛出的自定义错误 }