zoukankan      html  css  js  c++  java
  • 《JavaScript高级程序设计》学习笔记——错误处理与调试

    Author:chemandy

    第十四章 错误处理与调试

    1.开启浏览器错误报告

    1.1 Internet Explorer

    □Toos → Internet Option → Anvanced → Display a notification about every script error

    1.2 Firefox

    □Tools → Error Console  (Firebug)

    1.3 Safari

    □Edit  → Preferences → Advanced → Show develop menu in menubar/Develop  → Show Error Console

    1.4 Opera

    □Tools → Advanced → Error Console

    1.5 Chrome

    □Control this page → Developer → JavaScript console

    2.错误处理

    2.1 Try-catch语句

    try{

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

    }catch(error){

    //错误发生时怎么处理

    }

    □错误发生时catch快回收到一个包含错误信息的对象。有一个兼容所有浏览器的message属性。

    2.1.1 finally子句

    try-catch子句可选,finally子句一经使用,其代码无论如何都会执行。

    2.1.2 错误类型

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

    □EvalError:用eval()函数发生异常时抛出。

    □RangeError:数值超出相应范围时触发。

    □ReferenceError:找不到对象的情况下

    □SyntaxError:把语法错误的JavaScript字符串传入eval()函数。

    □TypeError:变量中保存着意外的类型时,或访问不存在的方法时。

    □URIError:使用encodeURI()或decodeURI(),而URI格式不正确时。

    根据不同的错误类型,进行错误处理:

    try{

    soemFunction();

    }catch(error){

    if(error instanceof TypeError){

    //处理类型错误

    }else if(error instanceof ReferenceError){

    //处理引用错误

    }else{

    //处理其他类型错误

    }

    }

    2.1.3 善用try-catch

    □使用try-catch语句,浏览器会认为错误已经被处理。

    □使用try-catch语句,最适用吹那些我们无法控制的错误。

    □明明白白地知道自己代码发生错误就不该用try-catch而是修复错误。

    2.2 抛出错误

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

    ②throw new Error("something bad happened."); 或利用原型链通过继承Error来创建自定义错误类型。

    2.2.1 抛出错误的时机

    2.2.2 抛出错误与使用try-catch

    2.2.3 错误(error)事件

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

    ②任何浏览器中,onerror事件处理程序都不会创建event对象。但可接受3个参数:错误消息、错误所在的URL和行号。(只有错误消息有用)

    ③指定onerror事件处理程序,必须使用DOM0级技术。

    window.onerror = function(message,url,line){

    alert(message);

    return false;  //通过返回false,此函数实际上充当了整个文档的try-catch语句可捕获所有无代码处理的运行时错误。

    };

    ④图像也支持error事件。只要图像的src特性中URL不能返回可以被识别的图像格式,就会触发error事件。此时的error事件遵循DOM格式,会返回一个以图像为目标的event对象。

    3.错误处理策略

    3.1 常见的错误类型

    □类型转换错误

    □数据类型错误

    □通信错误

    3.1.1 类型转换错误

    类型转换错误发生在使用某个操作符,或者使用其他可能会自动转换值的数据类型的语言结构时。在使用相等(==)和不相等(!==)操作符,或者if、for及while等流控制语句中使用非布尔值时,最常发生类型转换错误。

    3.1.2 数据类型错误

    在预料之外的值传给函数的情况下,最容易发生数据类型错误。

    3.1.3 通信错误

    ①URL格式不正确或发送的数据有问题。对查询字符串,必须使用encodeURIComponent()方法。

    ②在服务器响应的数据不正确时,也会发生通信错误。

    3.2 区分致命错误和非致命错误

    ①非致命错误

    □不影响用户的主要任务

    □只影响页面的一部分

    □可以恢复

    □重复相同操作可以消除错误

    ②致命错误

    □应用程序根本无法运行

    □错误明显影响到了用户的主要操作

    □会导致其他连带错误

    3.3把错误记录到服务器:(略)

    4.调试技术

    4.1 将消息记录到控制台

    ①IE8、Firefox、Chrome和Safari来说,可通过console对象向JavaScript控制台中写入消息。对象有下列方法:

    □error(message):将错误消息记录到控制台

    □info(message):将信息消息记录到控制台

    □log(message):将一般消息记录到控制台

    □warn(message):将警告消息记录到控制台

    ②还有一种方案是使用LiveConnect,也就是JavaScript中运行Java代码。

    ③向JavaScript控制台写入消息的统一接口:

    function log(message){

    if(typeof console == "object"){

    console.log(message);

    }else if(typeof opera == "object"){

    opera.postError(message);

    }else if(typeof java == "object" && typeof java.lang == "object"){

    java.lang.System.out.println(message);

    }

    }

    4.2 将消息记录到当前页面

    4.3 抛出错误

    ①对大型应用程序来说,自定义的错误通常使用assert()函数抛出。对这个函数接受两个参数,一个是求值结果为true的条件,另一个是条件为false时要抛出的错误。

    function assert(condition, message){

    if(!condition){

    throw new Error(message);

    }

    }

    ②应用:

    function divide(num1,num2){

    assert(typeof num1 == "number"&&typeof num2== "number","divide():Both arguments must be numbers.");

    return num1/num2;

    }

    5.常见的IE错误

    □操作终止

    □无效字符

    □未找到成员

    □未知运行时错误

    □语法错误

    □系统无法找到指定资源

  • 相关阅读:
    POJ1417 True Liars
    POJ2912 Rochambeau
    POJ3904 Sky Code
    [SDOI2016]排列计数
    POJ2947 Widget Factory
    HDU5015 233 Matrix
    Problem 2242. -- [SDOI2011]计算器
    POJ2480 Longge's problem
    Problem 2818. -- Gcd
    LA3510 Pixel Shuffle
  • 原文地址:https://www.cnblogs.com/chemandy/p/2166777.html
Copyright © 2011-2022 走看看