欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS中==、===你分清楚了嗎

 更新時間:2020年03月04日 09:32:11   作者:羞羞的王大錘  
這篇文章主要介紹了JS中==、===你分清楚了嗎,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

==、===都是相等運算符,這個大家應(yīng)該都知道,但二者有什么區(qū)別呢?其實==是相等,===是嚴(yán)格相等,那他們有什么本質(zhì)的區(qū)別呢?下面我就給大家細(xì)細(xì)道來。

  • =:賦值運算符
  • ==:判斷是否相等:忽略了類型進(jìn)行值的比較。
  • ===:判斷是否相等:先進(jìn)行值的比較,如果值相等,再去比較類型。即帶有類型的值的比較。

==相等

比較兩個值的時候,有兩種情況,一種如果兩個值的類型相同,就直接比較;另一種如果兩個值得類型不同,則會嘗試改變?yōu)橄嗤念愋驮谶M(jìn)行比較
第一種很好理解,直接比較完事兒,第二種就更有趣一些,它到底是怎么轉(zhuǎn)換的呢?下面我們一一列舉

數(shù)字和字符串比較

99 == ''99"

大家猜一猜結(jié)果是什么True?False?

結(jié)果為True
其實JS在數(shù)字和字符串比較時,都是把字符串轉(zhuǎn)換為數(shù)字,再對數(shù)字進(jìn)行比較的,舉個列子

99 == "chuichui"

JS是怎么轉(zhuǎn)換的呢?

99 == NaN // false

JS嘗試轉(zhuǎn)換字符串'chuichui',但是該字符串并不能轉(zhuǎn)換為數(shù)字,這時候轉(zhuǎn)換的結(jié)果就為NaN

布爾值和其他類型比較

其實JS在布爾值和其他類型比較時,都是把布爾值轉(zhuǎn)換為數(shù)字,再進(jìn)行比較的,舉個列子

1 == true
↓↓↓↓↓↓
1 == 1

JS會將true轉(zhuǎn)化為數(shù)字1,再做比較
那"1" == true又是怎么比較的呢?

"1" == true
↓↓↓↓↓↓
"1" == 1
↓↓↓↓↓↓
1 == 1 // true

轉(zhuǎn)換順序

  1. 將true轉(zhuǎn)換為1
  2. 將字符串“1”轉(zhuǎn)換為數(shù)字1
  3. 數(shù)字1和數(shù)字1比較

null和undefined比較

null == undefined

大家猜一猜,結(jié)果是True?False?

結(jié)果為True
是不是感覺很奇怪,但規(guī)則就是這樣。我們可以理解為都是“沒有值”
只不過一個是沒有值得變量,一個是沒有值的對象,因此他們相似

小心

有一個需要注意的地方,有些轉(zhuǎn)換你可能猝不及防

false == ""
True?False?

結(jié)果為True
轉(zhuǎn)換過程

  1. false轉(zhuǎn)化為0
  2. 空字符串""轉(zhuǎn)換為0,沒錯就是0 !
  3. 數(shù)字0和數(shù)字0比較

下面我們在說說嚴(yán)格相等 ===

===嚴(yán)格相等

有了前面的相等的定義,我想大家能猜個八九不離十,嚴(yán)格相等就是類型和值完全相同,這里不存在以上所存在的轉(zhuǎn)換問題

最后

操作數(shù)1 == 操作數(shù)2, 操作數(shù)1 === 操作數(shù)2

比較過程:

  雙等號==:

 ?。?)如果兩個值類型相同,再進(jìn)行三個等號(===)的比較

  (2)如果兩個值類型不同,也有可能相等,需根據(jù)以下規(guī)則進(jìn)行類型轉(zhuǎn)換在比較:

    1)如果一個是null,一個是undefined,那么相等

    2)如果一個是字符串,一個是數(shù)值,把字符串轉(zhuǎn)換成數(shù)值之后再進(jìn)行比較  

  三等號===:

 ?。?)如果類型不同,就一定不相等

 ?。?)如果兩個都是數(shù)值,并且是同一個值,那么相等;如果其中至少一個是NaN,那么不相等。(判斷一個值是否是NaN,只能使用isNaN( ) 來判斷)

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

 ?。?)如果兩個值都是true,或是false,那么相等

 ?。?)如果兩個值都引用同一個對象或是函數(shù),那么相等,否則不相等

 ?。?)如果兩個值都是null,或是undefined,那么相等

到此這篇關(guān)于JS中==、===的文章就介紹到這了,更多相關(guān)JS中==、===內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家

相關(guān)文章

  • javascript移出節(jié)點removeChild()使用介紹

    javascript移出節(jié)點removeChild()使用介紹

    這篇文章主要介紹了javascript節(jié)點操作移出節(jié)點removeChild()的使用,需要的朋友可以參考下
    2014-04-04
  • JS實現(xiàn)獲取本月的開始時間與結(jié)束時間

    JS實現(xiàn)獲取本月的開始時間與結(jié)束時間

    在JavaScript中,可以使用Date對象來獲取本月的開始時間和結(jié)束時間,本文通過代碼示例詳細(xì)的給大家介紹了JS獲取本月的開始時間與結(jié)束時間,感興趣的小伙伴跟著小編一起來看看吧
    2023-08-08
  • Js自定義多選框效果的實例代碼

    Js自定義多選框效果的實例代碼

    本篇文章主要介紹了Js自定義多選效果的實例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • JavaScript中公共的js文件寫法并在html的網(wǎng)頁中調(diào)用

    JavaScript中公共的js文件寫法并在html的網(wǎng)頁中調(diào)用

    這篇文章主要為大家詳細(xì)介紹了JavaScript中公共的js文件寫法并在html的網(wǎng)頁中調(diào)用的相關(guān)知識,文中的示例代碼講解詳細(xì),希望對大家有所幫助
    2025-09-09
  • mock.js模擬數(shù)據(jù)的實現(xiàn)

    mock.js模擬數(shù)據(jù)的實現(xiàn)

    在沒有后端提供數(shù)據(jù)的情況下,前端人員在自己寫demo或者練手項目的時候可以使用mock.js來模擬數(shù)據(jù),本文主要介紹了mock.js模擬數(shù)據(jù)的實現(xiàn),感興趣的可以了解一下
    2023-11-11
  • echarts餅圖labelLine線的長度自適應(yīng)設(shè)置

    echarts餅圖labelLine線的長度自適應(yīng)設(shè)置

    這篇文章主要給大家介紹了關(guān)于echarts餅圖labelLine線的長度自適應(yīng)設(shè)置的相關(guān)資料,在echarts中,餅圖的標(biāo)簽線可以通過設(shè)置 labelLine屬性來自定義位置,需要的朋友可以參考下
    2023-08-08
  • 理解javascript async的用法

    理解javascript async的用法

    本篇文章主要介紹了理解javascript async的用法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • Javascript將字符串日期格式化為yyyy-mm-dd的方法

    Javascript將字符串日期格式化為yyyy-mm-dd的方法

    日期格式化相信對于大家來說再熟悉不過,最近工作中自己利用Javascript就寫了一個,現(xiàn)在將實現(xiàn)的代碼分享給大家,希望對有需要的朋友們能有所幫助,感興趣的朋友們下面來一起看看吧。
    2016-10-10
  • 使用layui實現(xiàn)的左側(cè)菜單欄以及動態(tài)操作tab項方法

    使用layui實現(xiàn)的左側(cè)菜單欄以及動態(tài)操作tab項方法

    今天小編就為大家分享一篇使用layui實現(xiàn)的左側(cè)菜單欄以及動態(tài)操作tab項方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • es6新增對象的實用方法總結(jié)

    es6新增對象的實用方法總結(jié)

    在JavaScript中,幾乎每一個值都是某種特定類型的對象,于是ES6也著重提升了對象的功能性,下面這篇文章主要給大家介紹了關(guān)于es6新增對象實用方法的相關(guān)資料,需要的朋友可以參考下
    2022-05-05

最新評論