1. == 与 === 的区别
== 会先进行类型转换,再确定操作数是否相等。
=== 只有在两操作数不转换的前提下相等才返回true。
2. ==的使用
(1)转换操作数时,遵循如下规则:
- 若任一操作数是布尔值,则将其转换为数值再比较是否相等。false➡0,true➡1。
- 若一个操作数是字符串,另一个操作数是数值,则尝试将字符串转换为数值,再比较是否相等。
字符串转换数值的规则:
- 字符串包含数值字符(包含数值字符前带加、减号的情况),转换伪一个十进制数值
- 字符串包含有效的浮点数格式如"1.1",转换为相应浮点值
- 字符串包含有效的十六进制格式如"0xf",则会转换为与该十六进制对应的十进制整数
- 空字符串(不包含字符),则返回0
- 其他情况,返回NaN
- 若一个操作数是对象,另一个操作数不是,则调用对象的valueOf()方法取得其原始值,再根据前面的规则比较。
(2)进行比较时,遵循如下规则:
- null和undefined相等。
- null和undefined不能转换为其他类型的值再比较。
- 有任一操作数是NaN, == 返回false,!= 返回true。注意:NaN不等于NaN;
- 若两个操作符都是对象,则比较他们是不是同一个对象。若两者指向同一个对象,则 == 返回true,否则,两者不相等。
一些例子:
表达式 | 结果 |
---|---|
null == undefined | true |
“NaN” == NaN | false |
5 == NaN | false |
NaN == NaN | false |
NaN != NaN | true |
false == 0 | true |
true == 1 | true |
true == 2 | false |
undefined == 0 | false |
null == 0 | false |
“5” == 5 | true |
注:NaN是number类型的。
2. 判断以下哪些表达式为真值
(1)
console.log(null == 0);
console.log(undefined == "0");
console.log([] == []);
console.log([] == false);
console.log(NaN == false);
console.log(null == undefined);
答案:
false
false
false
true
false
true
注意:对于[] == false,存在object,左边先转化为原始值" ",于是左边为string, 右边为boolean,两者转为number后都为0
(2)
console.log(null === null);
console.log(NaN === NaN);
console.log(undefined === undefined);
运行结果:
true
false
true