浏览器异常信息捕获

2017-03-05  本文已影响0人  阿九是只大胖喵

在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;
}
上一篇 下一篇

猜你喜欢

热点阅读