js中数据类型分基本数据类型和引用数据类型,然后它们又再细分,那么它们之间的比较又是怎么进行的呢?刚接触这个,真的是把我弄得特别懵,不过总结完以后,做了些练习好了很多,下面我来捋一捋。
==
- 比较;返回一个布尔值;相等返回true,不相等返回false
- 允许不同数据类型之间的比较;
- 如果是不同类型的数据进行,会默认进行数据类型之间的转换;
console.log(1 == 1);// true
console.log(1 == "1");// true
console.log(1 == "1px");//false
console.log(1 == true);//true
console.log([]==false)// true
console.log([]==0)// true
console.log(100 == false);// false
console.log(188 == "188");// true
console.log(false == " ");// true
- 如果是对象数据类型的比较,比较的是空间地址
console.log({}==[])// false
console.log({}=={})// false
console.log([]=="")// true
console.log([]==0)// true
既然有这么多数据类型,那么它们的比较肯定不是毫无章法的!
- 数据类型比较规律
- 对象 ==布尔: 对象先转字符串再转数字,布尔转数字;
- 对象==对象: 比较是空间地址;
- 对象==数字 对象先转字符串,再转数字
- 对象==布尔: 对象先转字符串,再转数字,布尔转数字
- 对象==字符串 : 对象转字符串,字符串比较
- 布尔==字符串 : 布尔转数字,字符串转数字
- 布尔==数字: 布尔转数字
- 字符串==数字: 字符串转数字
{ } 对象toString 转换成字符串结果是"[object Object]"
!(取反) : 会先把后面的值进行去布尔,然后再取反,最后比较
0 " " NaN null undefined只有这五个值转布尔是false;
console.log(![] == [])// true
console.log([]==[])// false
console.log(![]==false);//true
console.log({a:1}=="[object Object]")// true
console.log("12px" == 12);
===
绝对比较; 只要数据类型不一样,那么返回false;
console.log(1 === 1);// true
console.log(1 === true);// false
console.log(1 === "1");// false