JS中错误处理

1 错误类型

  • 1. Error 是基本类型 其他错误都继承该类型
  • 2. EvalError 使用eval()函数时发生异常
  • 3. RangeError
  • 4. ReferenceError 找不到对象的情况下(导致object expected ),访问不存在的对象的时发生
  • 5. SyntaxError 语法错误
  • 6. TypeError 变量中保存着意外类型,或者在访问不存在的方法时
  • 7. URLError
try {
someFunction();
} catch (error) {
if (error instanceof TypeError) {
// c处理类型错误
} else if (error instanceof ReferenceError) {
// 处理引用错误
} else {
// 处理其他类型错误
} 
}

 

2.与try-catch语句相配的还有一个throw操作符,用于随时抛出自定义的错误

function process(values) {
if (!(values instanceof Array)) {
throw new Error("process():argument must be an array");//自定义错误的类型
}
values.sort();
for (var index = 0; index < values.length; index++) {
if (value[i] > 100) {
return values[i];
} 
}
return -1;
}

在js开发中尽量关注函数和可能导致函数执行失败的因素


3. 任何没有通过try-catch处理的错误都会触发window对象的error事件。只能用DOM0级事件,即onerror接受3个参数:错误信息,错误所在的URL和行号(大多数情况下,只有错误信息有用)

4. 图像也支持error事件

// 图像支持error事件
var image = new Image();
image.addEventListener('error', function (event) {
alert("image not load");
}, false);
image.src = "smile.gif"; //指定不存在的图像

5 js中常见的错误类型

  • 1. 类型转化错误:发生在使用了某个操作符(如js中的(==)和(!=)或者if while等流控制语句中的非布尔值)
  • 2. 数据类型错误 (在使用变量和函数参数之前,要检查数据类型是否会造成错误)
  • 3. 通信错误 js与后台服务器的通信
  • 注意:将数据发送给服务器之前(通过url),使用encodeURLComponent()对数据进行编码

6.把错误记录到服务器上
集中保存错误日志,一边找到错误原因

// 记录错误到服务器
function logError(sev, meg) {
//第一个参数说明表示错误的严重程度 meg值错误的类型自定义的信息 
var img = new Image();
img.src = "log.php?sev=" + encodeURIComponent(sev) + "&meg=" + encodeURIComponent(meg);
}
var array = [];
for (var index = 0; index < array.length; index++) {
try {
array[i].init();
} catch (error) {
logError("nonfatal", "module init failed:" + error.message);
}
}

7.console对象具有下列方法:

  •  error(message) 错误信息记录在控制台
  •  info(message) 将信息性消息记录到控制台
  •  log(message) 将一般消息记录到控制台
  •  warn(message) 将警告消息


8.// 一般对于大型程序 自定义错误都是通过assert()函数抛出

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;
}

9. 当使用innerHTML和outerHTML以下列方法指定HTML时,就会发生未知运行错误(unknown runtime error):

  • 1. 是把块级元素插入行内元素当中
  • 2. 访问表格任意部分(如<table> <tbody>)

 

posted @ 2017-11-26 13:23  sundjly  阅读(934)  评论(0编辑  收藏  举报