×

聊聊js里调试错误以及打印信息的知识

作者:andy0012020.02.10来源:Web前端之家浏览:3866评论:0
关键词:jsconsolealert

程序的非正常运行状态被称为“异常”或“错误”,解释器会为每个错误情形创建并抛出一个Error对象,其中包含错误的描述信息。

ECMAScript 定义了六种类型的错误:

ReferenceError   :找不到对象时
TypeError        :错误的使用了类型或对象的方法时
RangeError       :使用内置对象的方法时,参数超范围
SyntaxError      :语法写错了
EvalError        :错误的使用了Eval
URIError         :URI错误

除此之外,还可以使用Error构造方法创建自定义的Error对象,并使用throw语句抛出该对象。

创建错误

//创建一个错误
var err1 = Error("a is undefined!");
var err2 = new Error("a is undefined!");
console.log(typeof err1); //object
console.log(typeof err2); //object
console.log(err1);        //输出字符串:'Error: a is undefined!'  at test.html:21
console.log(err2);        //输出字符串:'Error: a is undefined!'  at test.html:21

抛出错误

throw语句用来抛出一个用户自定义的异常。当前函数的执行将被停止(throw之后的语句将不会执行),并且控制将被传递到调用堆栈中的第一个catch块。如果调用者函数中没有catch块,程序将会终止。

1、抛出了一个值为字符串的异常

throw "Error";              //控制台报错: Uncaught Error

2、抛出了一个值为整数13的异常

throw 13;                    //控制台报错: Uncaught 13

3、抛出了一个值为true的异常

throw true;                 //控制台报错: Uncaught true

4、抛出了一个错误对象

throw Error('abc');         //控制台报错: Uncaught Error: abc 
throw new Error('abc');     //控制台报错: Uncaught Error: abc

5、应用举例:提示函数调用中的错误

function sum(...number){
  var isNum = number.every( v => !isNaN(v));
    if(isNum){
        return eval(number.join("+"));        //数组求和
  }else{
      throw new Error("参数必须是数字或数字字符串!");  
  }
}
console.log(sum(1,2,3));     //6
console.log(sum(1,2,'3'));   //6
console.log(sum(1,2,'a3'));  //报错! Error: 参数必须是数字或数字字符串!

温馨提示:本文作者系 ,经Web前端之家编辑修改或补充,转载请注明出处和本文链接:
https://www.jiangweishan.com/article/js202009.html

网友评论文明上网理性发言 已有0人参与

发表评论:

最新留言

  • 土工膜

    资深程序员就是不简单...

  • 大吨位油缸

    谷歌浏览器使用起来很快,没有乱七八糟的插件。www.sdlyxt.com...

  • Web前端之家

    可以加Q群...

  • 访客

    JS点击锚点实现平滑滚动能写一个备注呗,有点看不懂,谢谢...

  • alice

    试用了下,vee-validate挺好用的!...

  • 访客

    封装思路跟原生javascript基本差不多。...

  • qianduan

    这个跟H5做的很像,看上去用react实现起来要简单些。...

  • qianduan

    YYDS的文章,收藏了。...

首页|JavaScript|HTML|HTML4|HTML5|CSS3|开发工具|性能优化|移动开发|前端教程|性能优化|开发工具|酷站欣赏|UI设计|前端教程

Copyright © 2021 Web前端之家(www.jiangweishan.com) 版权所有 All Rights Reserved.
粤ICP备12067512号-1

Copyright Your WebSite.Some Rights Reserved.

Powered By Z-BlogPHP 1.6.7 Valyria