美文网首页
浏览器异常信息捕获

浏览器异常信息捕获

作者: 阿九是只大胖喵 | 来源:发表于2017-03-05 22:37 被阅读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;
    }
    

    相关文章

      网友评论

          本文标题:浏览器异常信息捕获

          本文链接:https://www.haomeiwen.com/subject/oozegttx.html