浏览器异常信息捕获

在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;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 通俗编程——白话JAVA异常机制 - 代码之道,编程之法 - 博客频道 - CSDN.NEThttp://blog...
    葡萄喃喃呓语阅读 3,203评论 0 25
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,785评论 18 399
  • “三人行,必有我师焉”、”术业有专攻”,这些古训都告诉我们,每个人都有值得学习的地方,每一个人都有擅长的方面,或多...
    雨霖0307阅读 388评论 9 8
  • 首先本文主要讲述的是我眼中的交互设计,是针对我对交互设计的理解所写的文章,用于和大家交流职业发展。本文将从交互设计...
    金酱酱阅读 1,079评论 0 5
  • 你一定要对我好, 因为我一旦感觉不到你的温度会害怕,会失去对你的依赖感。 你要和我有满满的默契,我不一定说,但你一...
    弃无安阅读 380评论 0 2