日期:2014-05-16 浏览次数:20326 次
程序开发中,编程人员经常要面对的是如何编写代
码来响应错误事件的发生,即例外处理(exception
handlers)。如果例外处理代码设计得周全,那么最终呈现给用户的就将是一个友好的界面。否则,就会让访问者对莫名的现象感到真正的“意外”。
一、什么是例外处理
当JavaScript程序在运行中发生了诸如数组索引越界、类型不匹配或者语法错误时,JavaScript解释器就会引发例外处理。
ECMAScript定义了六种类型的错误,除此之外,我们可以使用Error对象和throw语句来创建并引发自定义的例外处理信息。
二、例外处理技术的优点
通过运用例外处理技术,我们可以实现用结构化的方式来响应错误事件的发生,让例外处理代码与正常脚本代码科学分离,最终使我们能够集中精力编写完成主
要功能的核心程序。
三、使用 try…catch…finally 执行例外处理
在JavaScript中,我们使用try…catch…finally语句来执行例外处理,即通过它来捕捉错误发生后导致的例外或者执行throw
语句产生的例外。它的基本语法如下:
try { // 此处是可能产生例外的语句 } catch(error) { // 此处是负责例外处理的语句 } finally { // 此处是出口语句 }?
try { document.writeln("开始执行try块语句 ---> ") document.writeln("还没有发生例外 ---> ") alert(eval(prompt("输入一个值:",""))) } catch(err) { document.writeln("捕捉到例外,开始执行catch块语句 --->"); document.writeln("错误名称: " + err.name+" ---> "); document.writeln("错误信息: " + err.message+" ---> "); } finally { document.writeln("开始执行finally块语句") }?
try { document.writeln("Beginnng the try block") document.writeln("No exceptions yet") // Create a syntax error eval("6 + * 3") document.writeln("Finished the try block with no exceptions") } catch(err) { document.writeln("Exception caught, executing the catch block") document.writeln("Error name: " + err.name) document.writeln("Error message: " + err.message) } document.writeln("Executing after the try-catch statement")?
function evalText() { try { alert(eval(prompt("Enter JavaScript to evaluate:",""))) } catch(err) { if(err.name == "SyntaxError") alert("Invalid expression") else alert("Cannot evaluate") } }?