js——异常

概念

程序中,因为语法的疏忽或其他原因而导致程序中途崩溃的情况,我们称之为异常。

每个异常在程序中都是作为对象而存在的

JavaScript内置异常类

1.ReferenceError:引用异常

        一般是使用了未定义的变量

2.SyntaxError:语法异常

        一般是指代码写错

3.TypeError:类型异常

        一般是值数据类型错误。比如参数类型不对

4.RangeError:范围异常

        错误的数组下标

5.URIError:地址异常

        子处理非法地址时出错,比如利用decodeURICompoent()来处理地址,地址中不允许有%,有则报URIError

处理异常(try-catch-finally)

语法

try{
    //可能会发生异常的代码
}catch(异常对象){
    //发生异常时会执行的代码,catch可以定义一个局部变量来接受当前的异常对象
}finally{
    //无论是否发生了异常 ,都会执行的代码
}

finally是可选的,一般在使用了硬盘资源(io)需要关闭使用的通道,才会用finally

不要把所有的代码都放到try里面,这样会导致程序过于集中,并且加大内存资源的消耗,一般是对局部的代码使用。

一般执行的顺序:try-catch-finally

主动抛出异常

概念:当程序执行到需要严格判断时,一般当不满足条件时,可以选择主动抛出异常

语法

throw new  异常类名('发生异常时的提示内容'); 

一般强业务逻辑时,会使用主动抛出异常。

自定义异常(ES6、ES5)

JavaScript内置异常并不能很好的满足业务需求。比如登录异常、注册异常等,利用自定义异常来解决

语法

class 自定义异常名 extends Error{
    constructor(message){
        super(message);
        this.name = "自定义异常名";
    }
}

自定义异常只能是主动抛出

es5实现自定义异常

自定义异常类名.prototype = new Error();
function 自定义异常类名(message){
    this.message = message;
    this.name ="自定义异常类名";
}

return在异常中的表现

无异常时,如果return在try里,会先保存要返回的数据,再去执行finally(如果有),执行之后就返回。

有异常时。返回catch里的return。

无论是否有异常,只要finally有return,那么执行的是finally里的return

异常对象的常见属性

name:发生异常的名字

message:发生异常的原因

stack:异常发生栈,会输出在那个位置发生了异常

你可能感兴趣的:(javascript,前端,java)