在javascript中使用这两个相等操作符的时候时常会有些疑惑,翻阅了一些书籍在此做一下总结。
使用==时,不同类型的值也可以被看作相等,也就是说==允许在相等比较中进行强制类型转换,而===不允许。如果比较的两个值类型相同,则==和===使用相同的算法,两者并没有什么区别。
这样看起来==貌似工作量更大一些,还需要进行强制类型转换…
当用==比较两个不同类型值的时候会发生隐式强制类型转换,不同类型间的比较也规定了以下几种情况:
字符串与数字间的相等比较
先看下例子
var a=42;
var b="42";
a===b; //false
a==b; //true
因为没有强制类型转换,所以a===b为false,42和“42”不相等。
而==的转换规则是将字符串ToNumber(b)转换为数字类型的,以此在进行比较。
与布尔类型的相等比较
var a="42";
var b=true;
a==b; //false
为什么是false呢,按理说”42”应该是一个真值,为啥结果不是true呢?在与布尔类型的值进行比较的时候,还是比较坑的。与它相比较的时候,js首先把将布尔类型的值进行ToNumber(b)转换为数字 类型的值,而false的值就是0,true的值就是1,在以上的示例中,先将b转为1,然后1在于a比较,而a是一个字符串,在按照上面字符串与数字的比较规则进行比较,结果自然就是false了。
null与undefined进行==比较的结果为true
对象与非对象之间相等比较
var a=2;
var b=[2];
a==b; //true
在于对象之间进行比较的时候,js会将对象b(数组也是对象)执行toPromitive(b)操作(返回valueOf()或toString()的原始值),上述示例将b转换为字符串“2”,然后在进行字符串与数字的比较规则进行比较。
“===”操作符只要两边的类型不相等就是false,这个简单多了。