首先,先做個簡單的介紹,讓先有個直觀的認識
== equality 等同 === identity 恒等
== 兩邊實值型別不同的時候,要先進行類型轉換,再比較。
=== 不做類型轉換,類型不同的一定不等。
舉例說明:
"1" == true
類型不同,"=="將先做類型轉換,把true轉換為1,即為 "1" == 1;
此時,類型仍不同,繼續進行類型轉換,把"1"轉換為1,即為 1 == 1;
此時,"==" 左右兩邊的類型都為數值型,比較成功!
如果比較:"1" === true 左側為字元型,右側為bool布爾型,左右兩側類型不同,結果為false;
如果比較:"1" === 1 左側為字元型,右側為int數值型,左右兩側類型不同,結果為false;
如果比較: 1 === 1 左側為int數值型,右側為int數值型,左右兩側類型相同,數值大小也相同,結果為true;
如果比較: 1 === 2 左側為int數值型,右側為int數值型,左右兩側類型相同,但數值大小不同,結果為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數組等),都[不相等]。
舉例說明:
"1" == true
類型不等,true會先轉換成數值 1,現在變成 "1" == 1,再把"1"轉換成 1,比較 1 == 1, 相等。
= 賦值運算子
== 等於
=== 嚴格等於
例:
var a = 3;
var b = "3";
a==b 返回 true
a===b 返回 false
因為a,b的類型不一樣 ===用來進行嚴格的比較判斷,結果為false
=============
var priceOfApple = "3元"; // 蘋果的價格
var priceOfBanana = "3.5元"; // 香蕉的價格
priceOfApple = parseInt( priceOfApple ); // 解析蘋果的價格
var priceOfBanana2 = parseInt( priceOfBanana ); // 解析香蕉的價格
if( ( priceOfApple===3 ) && ( priceOfBanana2 === 3 ) // 檢查解析是否成功
&& ( parseFloat( priceOfBanana ) ===3.5 ) )
{
alert( "蘋果的價格:" + priceOfApple // 輸出水果的價格
+ "/n香蕉的價格的整數部分:" + priceOfBanana2
+ "/n香蕉的價格:" + parseFloat( priceOfBanana ) );
}