首頁 > web前端 > 前端問答 > JavaScript怎麼判斷相不相等

JavaScript怎麼判斷相不相等

青灯夜游
發布: 2022-02-23 18:57:51
原創
3532 人瀏覽過

JavaScript判斷相不相等的方法:1、使用「==」或「!=」運算符,比較兩個運算符的值是否相等;2、使用「===」或「! ==”運算符,比較兩個運算元的值是否相等,同時偵測它們的型別是否相同。

JavaScript怎麼判斷相不相等

本教學操作環境:windows7系統、javascript1.8.5版、Dell G3電腦。

JavaScript判斷相不相等

#在JavaScript中,可以利用== ===!=!==運算子來判斷相等或不等於

說明比較兩個運算元的值是否相等
# #等值偵測運算子
==(相等)

#!=(不想等)
  • 比較兩個運算元的值是否不相等

  • #===(全等)

    比較兩個運算元的值是否相等,同時偵測它們的型別是否相同
  • !==(不全等)
  • 比較兩個運算數的值是否不相等,同時偵測它們的型別是否不相同

  • 在相等運算中,應注意以下幾個問題:

#如果操作數是布林值,則先轉換為數值,其中false 轉為0,true 轉換為1。

如果一個運算元是字串,另一個運算元是數字,先試著把字串轉換為數字。

如果一個運算元是字串,另一個運算元是對象,先試著把物件轉換為字串。

如果一個運算元是數字,另一個運算元是對象,先試著把對象轉換為數字。

如果兩個運算元都是對象,則比較參考位址。如果引用地址相同,則相等;否則不等。

  • 範例1
  • 下面是特殊運算元的相等比較。

    console.log("1" == 1);  //返回true。字符串被转换为数字
    console.log(true == 1);  //返回true。true被转换为1
    console.log(false == 0);  //返回true。false被转换为0
    console.log(null == 0);  //返回false
    console.log(undefined == 0);  //返回false
    console.log(undefined == null);  //返回true
    console.log(NaN == "NaN");  //返回false
    console.log(NaN ==1);  //返回false
    console.log(NaN == NaN);  //返回false
    console.log(NaN != NaN);  //返回true
    登入後複製
  • NaN與任何值都不相等,包括它自己。 null 和 undefined 值相等,但是它們是不同類型的資料。在相等比較中,null 和 undefined 不允許轉換為其他類型的值。
  • 範例2

下面兩個變數的值是相等的。

var a = "abc" + "d";
var b = "a" + "bcd";
console.log(a == b);  //返回true
登入後複製
數值和布林值的相等比較運算效率比較高,而字串需要逐個字元進行比較,相等比較運算效率比較低。

在全等運算中,應注意以下幾個問題:

如果兩個運算元都是簡單的值,只要值相等,型別相同,就全等。

如果一個運算元是簡單的值,另一個運算元是複合型對象,則不全等。

如果兩個運算元都是複合型對象,則比較參考位址是否相同。

範例3

下面是特殊運算元的全等比較。

console.log(null === undefined);  //返回false
console.log(0 === "0");  //返回false
console.log(0 === false);  //返回false
登入後複製

範例4

下面是兩個物件的比較,由於它們都引用了相同的位址,所以傳回 true。

var a = {};
var b = a;
console.log(a === b);  //返回true
登入後複製

下面兩個物件雖然結構相同,但是位址不同,所以不全等。

var a = {};
var b = {};
console.log(a === b);  //返回false
登入後複製

範例5

對於複合型對象,主要比較引用的位址,不比較對象的值。

在上面範例中,兩個物件的值相等,但是引用位址不同,所以它們既不想等,也不全等。因此,對於複合型物件來說,相等==​​和全等===運算的結果是相同的。

範例6#########對於簡單的值,只要型別相同、值相等,它們就是全等,不考慮表達式運算的過程變化,也不用考慮變量的引用位址。 ###
var a = "1" + 1;
var b = "11";
console.log(a ===b);  //返回true
登入後複製
######範例7#########表達式(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中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板