JavaScript中三個(gè)等號(hào)和兩個(gè)等號(hào)的示例分析-創(chuàng)新互聯(lián)

小編給大家分享一下JavaScript中三個(gè)等號(hào)和兩個(gè)等號(hào)的示例分析,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

十多年的石嘴山網(wǎng)站建設(shè)經(jīng)驗(yàn),針對(duì)設(shè)計(jì)、前端、開(kāi)發(fā)、售后、文案、推廣等六對(duì)一服務(wù),響應(yīng)快,48小時(shí)及時(shí)工作處理。營(yíng)銷型網(wǎng)站建設(shè)的優(yōu)勢(shì)是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動(dòng)調(diào)整石嘴山建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無(wú)論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計(jì),從而大程度地提升瀏覽體驗(yàn)。創(chuàng)新互聯(lián)建站從事“石嘴山網(wǎng)站設(shè)計(jì)”,“石嘴山網(wǎng)站推廣”以來(lái),每個(gè)客戶項(xiàng)目都認(rèn)真落實(shí)執(zhí)行。

引子

眾所周知,用在if條件判斷語(yǔ)句中,js有六種假值:false, null, undefined, '', NAN, 0。先來(lái)看幾個(gè)例子:

[] === []
NaN === NaN
NaN == NaN
0 == []
'' == []
'' == {}
[] == undefined
{} == []
null == undefined

以上這些判斷結(jié)果是什么,大家能否一看就知道結(jié)果呢?筆者以前對(duì)==和===都只有大概的印象,相信大家也都知道,== 判斷如果兩邊變量的類型不同,會(huì)將其先做類型轉(zhuǎn)換再作判斷,而 === 則不做類型轉(zhuǎn)換,如果類型不同,就一定返回 false。但是筆者最近看到了一個(gè)題目,感覺(jué)很有意思,貼出來(lái)給大家看看:

var x = 1;
var obj = {
  valueOf: function(){ 
    x = 2; 
    return 0 
    }
  }
console.log(obj == 0, x)

恩,這段代碼輸出的結(jié)果是 true, 2,是不是不可思議?還有~

var x = 1;
var obj = {
  valueOf: function(){ 
    return {} 
  }, 
  toString: function(){ 
    return {}
  }
 }
 console.log(obj == 0)

這段代碼直接拋出了異常: Uncaught TypeError: Cannot convert object to primitive value。

如果你和我一樣覺(jué)得很奇怪,那就繼續(xù)往下看吧~

===的規(guī)則

這個(gè)比較簡(jiǎn)單,我把規(guī)則羅列一下

  1. 如果類型不同,就不相等

  2. 如果兩個(gè)都是數(shù)值,并且是同一個(gè)值,那么相等,例外的是,如果其中至少一個(gè)是NaN,那么不相等。(判斷一個(gè)值是否是 NaN,只能用isNaN() 來(lái)判斷)

  3. 如果兩個(gè)都是字符串,每個(gè)位置的字符都一樣,那么相等;否則不相等。

  4. 如果兩個(gè)值都是true,或者都是false,那么相等。

  5. 如果兩個(gè)值都引用同一個(gè)對(duì)象或函數(shù),那么相等;否則不相等。

  6. 如果兩個(gè)值都是null,或者都是undefined,那么相等。

這里不難發(fā)現(xiàn),復(fù)合類型的數(shù)據(jù)(比如對(duì)象、數(shù)組、函數(shù)等)之間的比較不是比較他們的值是否相等,而是比較他們引用的對(duì)象是否一樣,因此也不難明白,為什么 [] === [] 判斷為false了。

比如:

JavaScript中三個(gè)等號(hào)和兩個(gè)等號(hào)的示例分析

==探究

看下 == 的規(guī)則

  1. 如果兩個(gè)值類型相同,進(jìn)行 === 比較。

  2. 如果兩個(gè)值類型不同,他們可能相等。根據(jù)下面規(guī)則進(jìn)行類型轉(zhuǎn)換再比較:

  3. 如果一個(gè)是null、一個(gè)是undefined,那么相等。

  4. 如果一個(gè)是字符串,一個(gè)是數(shù)值,把字符串轉(zhuǎn)換成數(shù)值再進(jìn)行比較。

  5. 如果任一值是 true,把它轉(zhuǎn)換成 1 再比較;如果任一值是 false,把它轉(zhuǎn)換成 0 再比較。

  6. 如果一個(gè)是對(duì)象,另一個(gè)是數(shù)值或字符串,把對(duì)象轉(zhuǎn)換成基礎(chǔ)類型的值再比較。對(duì)象轉(zhuǎn)換成基礎(chǔ)類型,利用它的toString或者valueOf方法。 js核心內(nèi)置類,會(huì)嘗試valueOf先于toString。例外的是Date,Date利用的是toString轉(zhuǎn)換。非js核心的對(duì)象,會(huì)比較麻煩,有興趣的同學(xué)可以研究一下

  7. 任何其他組合,都不相等。

看到這里,第六條,我們就可以明白,為什么上面的代碼會(huì)輸出意想不到的結(jié)果甚至拋出錯(cuò)誤了。

再來(lái)看一題:

if (x == 10) 
  x += 5

根據(jù)上面的規(guī)則,試想一下,如果我們輸入的x是字符串20,那么x的結(jié)果會(huì)變成什么樣?沒(méi)錯(cuò),就是205,而往往這種情況我們的目的是想計(jì)算20+5的值。

綜合上面的例子,不難看出,== 的比較看似會(huì)比較方便,比如 1 == '1' ,但是會(huì)埋下隱患,比如可能對(duì)類型做出錯(cuò)誤的假設(shè)。因此大多數(shù)人建議我們少用== 而盡量使用 ===,事實(shí)上我也推薦如果明確知道類型,還是最好用===。

再舉個(gè)簡(jiǎn)單的例子:團(tuán)隊(duì)協(xié)作中你肯定需要讀別人的代碼。而當(dāng)你看到==時(shí),要判斷清楚作者的代碼意圖是確實(shí)需要轉(zhuǎn)型,還是無(wú)所謂要不要轉(zhuǎn)型只是隨手寫了,還是不應(yīng)該轉(zhuǎn)型但是寫錯(cuò)了……所花費(fèi)的腦力和時(shí)間比明確的===(加上可能需要的明確轉(zhuǎn)型)要多得多。這樣一想,===不要好太多。

明白了==的機(jī)制,那么判斷這6個(gè)假值,就變得容易了。

簡(jiǎn)單看看幾個(gè)例子,大家看看是真是假~

false == ''
false == []
0 == []
'' == []
[] == []
[] == {}
null == undefined
false == undefined

總結(jié)

可以用一張圖來(lái)表達(dá) == 返回true的幾個(gè)假值:

JavaScript中三個(gè)等號(hào)和兩個(gè)等號(hào)的示例分析

一、首先看雙等號(hào)前后有沒(méi)有NaN,如果存在NaN,一律返回false。

二、再看雙等號(hào)前后有沒(méi)有布爾,有布爾就將布爾轉(zhuǎn)換為數(shù)字。(false是0,true是1)

三、接著看雙等號(hào)前后有沒(méi)有字符串, 有三種情況:

  1. 對(duì)方是對(duì)象,對(duì)象使用toString()或者valueOf()進(jìn)行轉(zhuǎn)換;

  2. 對(duì)方是數(shù)字,字符串轉(zhuǎn)數(shù)字;

  3. 對(duì)方是字符串,直接比較;

  4. 其他返回false

  5. 如果是數(shù)字,對(duì)方是對(duì)象,對(duì)象取valueOf()或者toString()進(jìn)行比較, 其他一律返回false

  6. null, undefined不會(huì)進(jìn)行類型轉(zhuǎn)換, 但它們倆相等

后記

我的建議是:如果你的的確確知道你在做什么(了解類型轉(zhuǎn)換的結(jié)果),可以用==;否則還是用===吧。

在網(wǎng)上無(wú)意中看到的圖,大家可以參考看看:

==號(hào)

JavaScript中三個(gè)等號(hào)和兩個(gè)等號(hào)的示例分析

===號(hào)

JavaScript中三個(gè)等號(hào)和兩個(gè)等號(hào)的示例分析

看完了這篇文章,相信你對(duì)“JavaScript中三個(gè)等號(hào)和兩個(gè)等號(hào)的示例分析”有了一定的了解,如果想了解更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道,感謝各位的閱讀!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站muchs.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

文章標(biāo)題:JavaScript中三個(gè)等號(hào)和兩個(gè)等號(hào)的示例分析-創(chuàng)新互聯(lián)
分享URL:http://muchs.cn/article30/dspcpo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供關(guān)鍵詞優(yōu)化、網(wǎng)站改版、App設(shè)計(jì)、網(wǎng)頁(yè)設(shè)計(jì)公司網(wǎng)站設(shè)計(jì)公司、微信小程序

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁(yè)設(shè)計(jì)