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错误

□操作终止

□无效字符

□未找到成员

□未知运行时错误

□语法错误

□系统无法找到指定资源

转载于:https://www.cnblogs.com/chemandy/archive/2011/09/04/2166777.html

《JavaScript高级程序设计》学习笔记——错误处理与调试相关推荐

  1. JavaScript高级程序设计学习笔记(三)

    分享一下第五章(引用类型)的笔记,内容比较多,我拆成了两部分,今天这部分是关于Object.Array.Date和RegExp类型的. 以下的笔记是书上一些我以前学习的时候,没有太重视的js基础知识, ...

  2. javascript高级程序设计学习笔记

    javascript高级程序设计,当枕头书已经好久了~zz  现在觉得自己在js的开发上遇到了一些瓶颈,归根究底还是基础太薄弱,所以重新刷一遍js高程希望有更新的认识. 一.javascript简介 ...

  3. javascript高级程序设计 学习笔记 第五章 上

      第五章   引用类型的值(对象)是引用类型的一个实例.在 ECMAScript 中,引用类型是一种数据结构, 用于将数据和功能组织在一起.它也常被称为类,但这种称呼并不妥当.尽管 ECMAScri ...

  4. JavaScript高级程序设计学习笔记二(在HTML中使用JavaScript)

    在 HTML 中使用 JavaScript 在html中使用JavaScript脚本有两种方式一种是嵌入在HTML中的脚本,另一种是引入外部的脚本.两种方式都离不开<script>元素. ...

  5. JavaScript高级程序设计学习笔记第二十章--JSON

    1.JSON:JavaScript Object Notation, JavaScript 对象表示法. 2.最重要的是要理解它是一种数据格式,不是一种编程语言.虽然具有相同的语法形式,但 JSON ...

  6. JavaScript高级程序设计---学习笔记(四)

    1.全局变量不能通过delete操作符删除,而直接在window对象上定义的属性可以. var age = 29;window.color = "red";delete age;/ ...

  7. JavaScript高级程序设计学习笔记----初识JavaScript

    一.JavaScript概述 1.JavaScript 介绍: 简称JS,是一种浏览器解释型语言,嵌套在HTML文件中交给浏览器解释执行.主要用来实现网页的动态效果,用户交互及前后端的数据传输等. 2 ...

  8. JavaScript高级程序设计--学习笔记(第六章)

    文章目录 第六章 面向对象的程序设计 1. 理解对象 1.1 属性类型 1.2 定义多个属性 1.3 读取属性的特性 2. 创建对象 2.1 工厂模式 2.2 构造函数模式 2.3 原型模式 2.4 ...

  9. JavaScript高级程序设计学习笔记--引用类型

    Object类型 对象字面量表示法: var person={ name:"Nicholas", age:29, 5:true }; 这人例子会创建一个对象,包含三个属性:name ...

  10. JavaScript高级程序设计学习笔记--事件

    HTML事件处理程序 <input type="button" value="Click Me" onclick"showMessage()&q ...

最新文章

  1. ActiveMQ入门教程(三) - ActiveMQ P2P版的HelloWorld
  2. MyEclipse显示 Install new software 在线安装插件选项
  3. 流量银行与阿里联手放大招 1毛钱换1块钱
  4. 监控聚币网行情 并实时发送到微信
  5. 8大行业场景!最新 Apache Flink 行业案例集火热出炉
  6. 集中式整合之加入springsecurity
  7. c语言非线程安全函数引发的BUG一列
  8. 转:谈谈Unicode编码,简要解释UCS、UTF、BMP、BOM等名词
  9. java判断一个字符串是否为空,isEmpty和isBlank的区别
  10. async与defer
  11. SpringAOP 学习笔记
  12. 佛说剖腹产的孩子_选择好的剖腹产时间会改变孩子的命运吗?
  13. gmt绘制江苏省高程异常图
  14. 如何在SOLIDWORKS中使用PDM模板?
  15. 如何利用视频做动图?视频转gif动图
  16. BUUCTF_Web题目题解记录2
  17. alertmanager设置告警邮件的邮件头/邮件模板
  18. BVH后缀文件格式解析
  19. adobe audition不能扫描vst插件的解决参考
  20. win10中配置gopath环境变量遇到的问题

热门文章

  1. java有理数类的封装_第4章类与对象==有理数的类封装(分数的四则运算)
  2. 云计算—多云(1)-ielab
  3. 产品营销新招:短视频营销策略分析教你轻松占领市场!
  4. nginx做反向代理时出现302错误
  5. Go语言入门——环境准备篇(一)
  6. 32位地址为什么是4GB
  7. 【shader学习历程】翻页特效
  8. 唯一上市运动相机厂商GoPro遭遇退市危机
  9. SDUSTOJ 1466 - 编写函数:递归求逆序 (Append Code)
  10. 算法:判断能否形成等差数列