Javascript 有兩種方法來判斷兩種值是否相等。
相等符號
相等符號由兩個等號組成: ==
Javascript 是弱類型語言。這就意味著相等符號為了比較兩個值將會強制轉換類型。
代碼如下:
"" == "0" // false
0 == "" // true
0 == "0" // true
false == "false" // false
false == "0" // true
false == undefined // false
false == null // false
null == undefined // true
" \t\r\n" == 0 // true
上面的代碼展示了類型轉換的結果,因此我們知道使用相等符號 == 是個不好的編程習慣。由於 Javascript 中復雜的類型轉換機制,將會使得由此產生的錯誤變得難以追蹤。
此外,類型的強制轉換會對性能也造成一定的影響,例如,當一個字符串與數字進行比較時,會被強制轉換為數字。
嚴格相等符號
嚴格相等符號由三個等號組成: ===
它跟相等符號的操作相似,但是嚴格相等符號不會做強制類型轉換的操作。
代碼如下:
"" === "0" // false
0 === "" // false
0 === "0" // false
false === "false" // false
false === "0" // false
false === undefined // false
false === null // false
null === undefined // false
" \t\r\n" === 0 // false
上面的代碼使得代碼更加清晰,如果兩個值的類型不同則直接返回 false,這也會使得性能得到提升。
比較對象
盡管 == 和 === 被稱為相等符號,但是當比較的兩個值中有一個類型是對象時,表現將大不相同。
代碼如下:
{} === {}; // false
new String('foo') === 'foo'; // false
new Number(10) === 10; // false
var foo = {};
foo === foo; // true
在這兒,不再僅僅是比較兩個值是否相等,它將判斷兩個值是否引用同一個對象實例,這個行為比較像 C 中的指針。
總結
這裡強烈建議只使用嚴格相等符號 ===。如果我們需要做類型轉換,可以在比較前先做顯式的類型轉換,而不是靠 Javascript 本身復雜的強制轉換方法。