1. 程式人生 > >JavaScript等於 == 與 恆等於 === 的區別

JavaScript等於 == 與 恆等於 === 的區別

       JavaScript 是弱型別語言,這就意味著,等於操作符會為了比較兩個值而進行強制型別轉換。注意0的相等運算,例如:

""           ==   "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  

 而恆等於不像普通的等於操作符,不會進行強制型別轉換。這樣的話上述的結果就不太相同了:

""           ===   "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。

===表示恆等於,比較的兩邊要絕對的相同

alert(0 == ""); // true

alert(0 == false); // true

alert("" == false); // true

alert(0 === ""); // false

alert(0 === false); // false

alert("" === false); // false

先說 ===,這個比較簡單,具體比較規則如下:

1、如果型別不同,就[不相等] 

2、如果兩個都是數值,並且是同一個值,那麼[相等];(!例外)的是,如果其中至少一個是NaN,那麼[不相等]。(判斷一個值是否是NaN,只能用isNaN()來判斷) 

3、如果兩個都是字串,每個位置的字元都一樣,那麼[相等];否則[不相等]。 

4、如果兩個值都是true,或者都是false,那麼[相等]。 

5、如果兩個值都引用同一個物件或函式,那麼[相等];否則[不相等]。 

6、如果兩個值都是null,或者都是undefined,那麼[相等]。

再說 ==,具體比較規則如下:

1、如果兩個值型別相同,進行 === 比較,比較規則同上 

2、如果兩個值型別不同,他們可能相等。根據下面規則進行型別轉換再比較: 

a、如果一個是null、一個是undefined,那麼[相等]。 

b、如果一個是字串,一個是數值,把字串轉換成數值再進行比較。 

c、如果任一值是 true,把它轉換成 1 再比較;如果任一值是 false,把它轉換成 0 再比較。 

d、如果一個是物件,另一個是數值或字串,把物件轉換成基礎型別的值再比較。物件轉換成基礎型別,利用它的toString或者valueOf方法。js核心內建類,會嘗試valueOf先於toString;例外的是Date,Date利用的是toString轉換。非js核心的物件,令說(比較麻煩,我也不大懂) 

e、任何其他組合(array陣列等),都[不相等]。