错误处理与调试(一)

IE、FIrefox、Safari、Chrome、Opera等主流浏览器都有某种向用户报告JavaScript错误的机制,开启浏览器的JavaScript报告功能,可以及时收到错误通知。

    开发人员在处理错误的时候可以使用的手段和工具有:

1.try-catch语句

try {

            window.someNonexistentFunction();

        } catch (error){

            alert(error.name); //name属性是保存错误类型

            alert(error.message);//massage属性是保存错误消息的

        }

    这个massage对象是唯一一个能保证所有浏览器都支持的属性。IE添加了与massage属性完全相同的description属性,还添加了保存内部错误数量的number属性。Firefox添加了fileName、lineNumber、和stack属性。Safari添加了line、sourceId和sourceURL属性。但是在跨浏览器编程时最好还是只使用massage属性。

2.finally子句

    finally子句一旦使用,其代码无论如何也会执行,如果在try-catch中有返回的值,但是最后finally里也有返回的值,那么只会返回finally里的值,反之,会返回try-catch里的值。

3.错误类型

    ECMA-262定义了以下7种错误类型。

    Error:基类型,其它错误都继承自该类型。

    EvalError:会在使用eval()函数而发生异常时被抛出。

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

    ReferenceError:找不到对象时触发。

    SyntaxError:把语法错误的js字符串传入eval()函数时触发。

    TypeError:变量类型不符合操作时触发。

    URIError:在使用encodeURI()或decodeURI()而URI格式不正确时触发。

4.抛出错误

    throw操作符用于随时抛出自定义错误,在遇到throw时,代码会立即停止执行,仅当有try-catch语句捕获到被抛出的值时,代码才会继续执行。自定义错误可以和浏览器错误区别对待,想要在几千行代码中查找错误是什么,浏览器的错误消息通常不会告诉的很清楚,这时候带有适当信息的自定义错误就能够提升代码的可维护性。

if (!(values instanceof Array)){   //如果value不是一个数组,就会抛出一个错误

                throw new Error("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;

        }

   

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  •   由于 JavaScript 本身是动态语言,而且多年来一直没有固定的开发工具,因此人们普遍认为它是一种最难于调...
    霜天晓阅读 4,121评论 0 1
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 32,481评论 18 399
  • 第2章 基本语法 2.1 概述 基本句法和变量 语句 JavaScript程序的执行单位为行(line),也就是一...
    悟名先生阅读 9,711评论 0 13
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,833评论 19 139
  • 精灵刀阅读 669评论 0 0

友情链接更多精彩内容