在javascript中,恆等運算子是“===”,用來比較等式兩邊的運算元是否相等。 「===」在比較運算時,不只會比較兩個操作數的值是否相等,還會偵測它們的型別是否相同;只要值相等,型別相同,就會傳回true。
本教學操作環境:windows7系統、javascript1.8.5版、Dell G3電腦。
在javascript中,恆等運算子是“===”,用來比較等式兩邊的運算元是否相等。
“===”運算子在比較運算時,不僅會比較兩個運算元的值是否相等,還會偵測它們的型別是否相同。
在恆等運算中,應注意以下幾個問題:
如果兩個運算元都是簡單的值,只要值相等,型別相同,就全等。
如果一個運算元是簡單的值,另一個運算元是複合型對象,則不全等。
如果兩個運算元都是複合型對象,則比較參考位址是否相同。
(1)如果型別不同,就一定不相等
(2)如果兩個都是數值,且是同一個值,那麼相等;如果其中至少一個是NaN,那麼不相等。 (判斷一個值是否是NaN,只能用isNaN( ) 來判斷)
(3)如果兩個都是字串,每個位置的字元都一樣,那麼相等,否則不相等。
(4)如果兩個值都是true,或是false,那麼相等
(5)如果兩個值都引用同一個物件或是函數,那麼相等,否則不相等
(6)如果兩個值都是null,或是undefined,那麼相等
範例1
##下面是特殊運算元的全等比較。console.log(null === undefined); //返回false console.log(0 === "0"); //返回false console.log(0 === false); //返回false
範例2
下面是兩個物件的比較,由於它們都引用了相同的位址,所以傳回 true。var a = {}; var b = a; console.log(a === b); //返回true下面兩個物件雖然結構相同,但是位址不同,所以不全等。
var a = {}; var b = {}; console.log(a === b); //返回false
範例3
對於複合型對象,主要比較引用的位址,不比較對象的值。var a = new String("abcd); //定义字符串“abcd”对象 var b = new String("abcd); //定义字符串“abcd”对象 console.log(a === b); //返回false console.log(a == b); //返回false在上面範例中,兩個物件的值相等,但是引用位址不同,所以它們既不想等,也不全等。因此,對於複合型物件來說,相等==和全等===運算的結果是相同的。
範例4
對於簡單的值,只要型別相同、值相等,它們就是全等,不考慮表達式運算的過程變化,也不用考慮變量的引用位址。var a = "1" + 1; var b = "11"; console.log(a ===b); //返回true
範例5
表達式(a>b || a==b)與表達式(a>=b)並不完全相等。var a = 1; var b = 2; console.log((a > b || a == b) == (a >= b)); //返回true,此时似乎相等如果為變數 a 和 b 分別賦值 null 和 undefined,則傳回值 false,說明這兩個表達式並非完全等價。
var a = null; var b = undefined; console.log((a > b || a == b) == (a >= b)); //返回false,表达式的值并非相等因為 null == undefined 等於 true,所以表達式(a > b || a == b)的回傳值為 true,但是表達式 null >= undefined 的回傳值為 false。 【相關推薦:
以上是javascript恆等運算子是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!