JS中null和undefined的区别
一、undefined的理解
undefined的产生为初始化的时候,如果没有进行赋值,它是一个预定义的全局变量,在你没有进行对某个变量进行赋值的时候,他会被赋为undefined。
二、null的理解
null是人为进行赋值的。比如某个函数或者数组等等复杂类型,你如果想要进行一个舍弃,可以把它赋值为null。此时浏览器会进行一个回收。
其中typeof(null)会是一个object。最初这么设计的原因为:通常用作一个空引用一个空对象的预期,就像一个占位符。typeof的这种行为已经被确认为一个错误,虽然提出了修正,出于后兼容的目的,这一点已经保持不变。这也是上面为什么说可以把一个准备舍弃的复杂类型赋值为null的原因。
三、null与undefined的区别
1.类型不一样:
console.log(typeof null);
console.log(typeof undefined);
2.转换类型不一样
console.log(Number(null));
console.log(Number(undefined));
3.null和undefined在双等于和三等于的情况比较
console.log(null == undefined); //两个等于号会调用Number方法,最终转换成两个0相比较
console.log(null === undefined);//三个等于号会比较数据类型,所以直接返回false
相等运算符(==和!=)使用抽象相等比较算法比较两个操作数。可以大致概括如下:
-
如果两个操作数都是对象,则仅当两个操作数都引用同一个对象时才返回true。
-
如果一个操作数是null,另一个操作数是undefined,则返回true。
-
如果两个操作数是不同类型的,就会尝试在比较之前将它们转换为相同类型:
– 当数字与字符串进行比较时,会尝试将字符串转换为数字值。
– 如果操作数之一是Boolean,则将布尔操作数转换为1或0。
如果是true,则转换为1。
如果是 false,则转换为0。 -
如果操作数之一是对象,另一个是数字或字符串,会尝试使用对象的valueOf()和toString()方法将对象转换为原始值。
-
如果操作数具有相同的类型,则将它们进行如下比较: String:true仅当两个操作数具有相同顺序的相同字符时才返回。
-
Number:true仅当两个操作数具有相同的值时才返回。+0并被-0视为相同的值。如果任一操作数为NaN,则返回false。
-
Boolean:true仅当操作数为两个true或两个false时才返回true。
此运算符与严格等于(===)运算符之间最显着的区别在于,严格等于运算符不尝试类型转换。相反,严格相等运算符始终将不同类型的操作数视为不同。
4.null是原型链的出口
console.log(Object.prototype.__proto__ === null); //true