首頁  >  文章  >  web前端  >  javascript恆等運算子是什麼

javascript恆等運算子是什麼

青灯夜游
青灯夜游原創
2022-02-15 17:44:003115瀏覽

在javascript中,恆等運算子是“===”,用來比較等式兩邊的運算元是否相等。 「===」在比較運算時,不只會比較兩個操作數的值是否相等,還會偵測它們的型別是否相同;只要值相等,型別相同,就會傳回true。

javascript恆等運算子是什麼

本教學操作環境: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學習教學

以上是javascript恆等運算子是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn