Javascript高级程序设计第17章(错误处理与调试)

1.try-catch语句

 try{  //可能会导致错误的代码

}catch(error){  //在发生错误时怎么处理

//alert(error.message);

//alert(error.name),例如TypeError

}

与其他语言不同,即使你不想使用这个错误对象,也要给它起个名字

message属性是所有浏览器都支持的属性,它保存着错误消息

finally子句

function testFinally(){
            try {
                return 2;
            } catch (error){
                return 1;
            } finally {
                return 0;
            }
        }
        
        function testWithoutFinally(){
            try {
                return 2;
            } catch (error){
                return 1;
            }
        }
        
        alert(testFinally());
        alert(testWithoutFinally());

只要代码中包含finally子句,则无论try或catch语句块中包含什么代码----甚至return语句,也不会阻止finally子句的执行


2.错误类型

Error:这个基类型的主要目的是供开发人员抛出自定义错误

ReferenceError:通常在访问不存在的变量时,就会发生这种错误

SyntaxError:顾名思义

TypeError:在变量中保存着意外的类型时,或者在访问不存在的方法。归根到底还是由于在执行特定于类型的操作时,变量的类型并不符合要求所致。

合理使用try-catch:使用try-catch最适合那些我们无法控制的错误。在大型项目中,我们不能修改这个项目的代码,大可将函数的调用放在try-catch语句中。


3.抛出错误

与try-catch语句相配的还有一个throw操作符,用于随时抛出自定义错误。在遇到throw操作符时,代码会立即停止执行。仅当有try-catch语句捕获到被抛出的值时,代码才会继续执行。

抛出错误,我们认为只应该捕获那些你确切地知道该如何处理的错误。捕获错误的目的在于避免浏览器以默认方式处理它们;而抛出错误的目的在于提供错误发生具体原因的消息。

如 throw new Error("some text"); 

可以利用原型链来继承Error来创建自定义错误

function CustomError(message){       
            this.name = "CustomError";
            this.message = message;
        }
        
        CustomError.prototype = new Error();
    
        function process(values){
        
            if (!(values instanceof Array)){
                throw new CustomError("process(): Argument must be an array.");
            }
        
            values.sort();
        
            for (var i=0, len=values.length; i < len; i++){
                if (values[i] > 100){
                    return values[i];
                }
            }
        
            return -1;
        }

        process("string");


4.错误事件

①任何没有通过try-catch处理的错误都会触发window对象的error事件。

如果要执行onerror事件处理程序,必须使用DOM0级技术,它没有遵循“DOM2级事件”的标准格式。

它接受三个参数:错误消息、错误所在的URL和行号。只有错误消息最有用

只要发生错误,无论是不是浏览器生成的,都会触发error事件

window.onerror = function(message, url, line){
            alert(message);
            return false;
        };
        throw new Error("Something bad happened.");

return false 这行代码可以阻止浏览器报告错误的默认行为

通过返回false,这个函数实际上就充当了整个文档中的try-catch语句,可以捕获所有无代码处理的运行时错误。这个事件处理程序是避免浏览器报告错误的最后一道防线,理想情况下,只要可能就不应该使用它。只要能够适当地使用try-catch语句,就不会又错误交给浏览器,也就不会触发error事件。

②图像也支持error事件

只要图像的src特性中的URL不能返回可以被识别的图像格式,就会触发error事件。反之,触发onload事件


5.常见的错误类型

①类型转换错误,在if、for、while等流控制语句中使用非布尔值时,最常发生类型转换错误

建议使用全等(===)和不全等(!==)操作符来比较数值,以避免类型转换

②数据类型错误

识别类型对于非对象用typeof,对象用 instanceof

③通信错误

第一种错误通信错误与格式不正确的URL或发送的数据有关。最常见的问题是在数据发送给服务器之前,没有使用encodeURLComponent()对数据进行编码。

对于查询字符串,应该记住必须要使用encodeURLComponent()方法


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值