在JavaScript中使用try, catch 进行浏览器的异常信息捕获:
console.log(num); // -> num is not defined, 在JavaScript中,本行报错,下面的代码都不再执行了
console.log('ok'); // 不能输出,执行不到
语法
try {
// <JavaScript cod>
} catch (e) {
// 如果代码执行错误,执行catch中的代码
} finally {
// 一般不用: 不管try中的代码是否报错,都要执行finally中的代码
}
-> try {...} 中的代码执行报错,会捕获异常信息,不影响下面的代码继续执行;如果try中代码执行执行错误,会默认的去执行catch中的代码。
try {
console.log(num);
} catch (e) { // -> 形参不需要写,一般起名为e
console.log('报错了'); // -> 输出
console.log(e.message); // -> 可以收集当前代码报错的原因(num is not defined)
}
console.log('ok'); // -> 输出 ok
需求:有时候既想捕获到错误信息,又想不让下面代码继续执行,这时可以使用抛出异常来解决。
try {
console.log(num);
} catch (e) {
// -> 手动抛出一条错误信息,终止代码继续执行
throw new Error('当前网络繁忙,请稍后再试...');
// new ReferenceError(); -> 引用错误
// new TypeError(); -> 类型错误
// new RangeError(); -> 范围错误
}
console.log('ok');
应用:将数组转化为类数组
function listToArray(likeArray) {
var ary = [];
try {
ary = Array.prototype.slice.call(likeArray);
} catch (e) {
for (var i = 0; i < likeArray.length; i++) {
ary[ary.length] = likeArray[i];
}
}
return ary;
}