在网上看博客过程中,看到这样一个问题:
console.log([1] === [1]); //false
console.log({name: 'a'} === {name: 'a'}); //false
console.log([1] == [1]); //false
console.log({name: 'a'} == {name: 'a'}); //false
按照代码上来看,被比较双方的值是一样的,类型是一样的,返回肯定会是true,但是放在编译器中返回的却是false;原因如下:
首先,重新复习下概念:
1、'==': 相等运算符号;
2、'===':严格相等运算符号;
严格运算符的运算规则:
1、两个不同数据类型的值进行比较时,直接返回false;
2、两个同一数据类型的原始类型值(数值、字符串、布尔值)进行比较时,若值相同,返回true,否则返回false;
3、两个同一数据类型的复合类型值(数组,对象)进行比较时,不是比较值是够相同,而是比较它们是否指向同一内存地址;
4、null和undefined与自身严格相等;
相等运算符的运算规则:
1、相同的数据类型与严格运算符一样;
2、比较不同数据类型的数据时,相等运算符会先将数据进行类型转换,然后用严格相等运算符比较;
其中,类型转换规则如下:
1、原始类型值之间的比较,会首先转换成数值类型,然后再进行比较;字符串和布尔值都会转换成数值;
2、undefined和null与其他类型的值比较时,结果都是false,它们互相比较时结果为true;
js的数据类型:
1) 5种简单数据类型(也称为基本数据类型):Undefined、Null、Boolean、Number和String;
2)1种复杂数据类型Object,Object本质上是由一组无序的名值对组成的;
3)除此之外,还包括2种复杂的数据类型:Array,function 。