Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 415|回复: 0

【javascript进阶】异常

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-7-22 18:45:45 | 显示全部楼层 |阅读模式

    前言

    最近有些时间了,今天看了看博客的后台记录,好多都没有写博客呢,争取尽快把以前的补上,javascrit中的异常在前端大家用的好像不是很多,其实javascript的异常和大多数的后端语言差不大,今天和大家简单的介绍介绍,这里不介绍啥是运行时异常......,这是说些javascript常用的异常和异常处理。

    异常

    使用关键字Error我们可以像new一个普通的对象一样创建一个异常的实例,

    var err = new Error("这是一个异常");
    

    异常的属性如下:

    description: 错误描述  

    fileName: 出错的文件名 

    lineNumber: 出错的行数

    message: 错误信息 

    name: 错误类型  

    number: 错误代码 

    stack: 像Java中的Stack Trace一样的错误堆栈信息

    上面各个浏览器之间会有不兼容的现象,大家了解基本的就行。

    子类:

    Error是所有异常的父类了,他有许多的子类,像

    TypeError    当遇到一个意外的类型时引发该异常对象,如未声明的变量。   

    SyntaxError   在解析js代码时,其中的语法错误引发该异常对象。   

    ReferenceError   使用一个无效的引用时引发该异常对象。   

    EvalError    在错误的调用eval函数时引发该异常对象。   

    RangeError    在一个数字型变量的值超出了其范围时引发该异常对象。   

    URIError   在错误的使用encodeURI或者decodeURI函数时引发该异常对象。

    等等。     

    捕获

    try catch

    其实捕获异常是我们最关注的问题,我们不会没事自己new出来一个异常吧,那不是没事干了吗,我们了解异常是为了更好的处理它们。和其它的后端语言一样,javascript使用try{}catch(){}捕获异常,

    try{
      //可能出现异常的代码部分  
    }catch(e){
        //处理异常
    }finally{
        //任何时候都会执行
    }
    

    弄个实际的例子

    try{
    	unde  //未定义的变量
    }catch(e){
    	console.dir(e);
    }finally{
    	alert("finally");
    }
    

    这就是捕获代码本身出现的错误,我们可以认为的抛出一些异常,这就是throw关键字的作用了,看两个例子

    try{
      throw new Error("抛出一个异常");  //抛一个异常
    }catch(e){
      alert(e.message);   //catch到异常
    }
    

    再看一个

    try{
      throw("抛出一个异常");  //抛一个字符串
    }catch(e){
      alert(e);   //catch到这个字符串
    }
    

    throw可以抛出任何的对象,在catch中可以捕获到。

    onerror

    另外一种捕获javascript的异常就是window.onerror = function(){},就是和普通的事件一样,监听异常事件,他有一些参数,各个浏览器可能会不一致,看看具体的用法

    window.onerror = function(message, URI, lineNumber,columnNumber,errorObj) {
           console.log("错误信息:" , nessage);
           console.log("出错文件:" , URI);
           console.log("出错行号:" , lineNumber);
           console.log("出错列号:" , columnNumber);
           console.dir(errorObj);
        }
    throw new Error("我的异常');
    

    结果是这样的:

    虽然我们捕获了出现的异常,但是浏览器还是默认会把错误信息显示出来,我们在window.onerror = function(){} 加个返回值return true就不会显示默认的错误信息了,这样

    window.onerror = function(message, URI, lineNumber,columnNumber,errorObj) {
           console.log("错误信息:" , nessage);
           console.log("出错文件:" , URI);
           console.log("出错行号:" , lineNumber);
           console.log("出错列号:" , columnNumber);
           console.dir(errorObj);
           return true;
        }
    throw new Error("我的异常');
    

    这样就不显示浏览器默认的错误信息了。利用这个我们就可以忽略所有的错误了,可以搞下恶作剧啥的,就这样

    window.onerror = function(){
      return true;  
    }

    其实如果我们不重新onerror这个方法,原来就是空的,所以不写的话我们得不到一些异常信息。

    异步中的异常

    首先我们看一下简单的异步函数,最简单的就是setTimeout了

    setTimeout(function(){console.log(1)},1000);
    

    That's all,简单吧,骗你的,异步以后会将的,先这样哈,异步不是今天的主角,我们在异步函数中抛出一个异常试试

    setTimeout(function(){throw new Error("我的异常")},1000);
    

    现在我们进行异常的捕获,第一个方法try catch

    try{
      setTimeout(function(){throw new Error("我的异常")},1000);  
    }catch(e){
      alert(e.message);  
    }
    

    这样累死也捕获不到异常的,因为当trycatch执行的时候 function(){throw new Error("我的异常")还没有在内存堆栈中呢,这个大家先有点印象,以后在异步中会详细说的,记住这样是不能捕获错误的。

    当然你在里面这样是可以捕获的

    setTimeout(function(){
                                try{throw new Error("我的异常")
                                    }catch(e){
                                               alert(e.message);  
                                                }
                        },1000); 
    

    我们可以使用window.onerror的方式来捕获异步的异常,这样

    window.onerror = function(message, URI, lineNumber,columnNumber,errorObj) {
           console.log("错误信息:" , message);
           console.log("出错文件:" , URI);
           console.log("出错行号:" , lineNumber);
           console.log("出错列号:" , columnNumber);
           console.dir(errorObj);
    	   return true;
        }
    setTimeout(function(){throw new Error("我的异常")},1000);
    

    这样肯定是可以的,因为是属于监听的方式,啥时候有错误啥时候执行。

    小结

    这样,咱就了解了javascript的异常处理的基础了,有兴趣的同学再深入了解吧。

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-12-23 09:09 , Processed in 0.165737 second(s), 30 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表