国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

JavaScript 中 == 和 === 的區別

Chao / 942人閱讀

摘要:例如兩個引用類型判斷兩者之間的引用路徑。布爾值與數字比較時,布爾值轉化成數字值,二者再進行比較。根據運算符的優先級,先執行,直接轉化為布爾值空字符串,,,都是,其余都是再取反,故轉化為。最后,故結果為。

兩個操作數之間的 " == " 與 " === "

1、 兩個不同的基本數據類型: 如果兩個基本數據類型(Number、String、Boolean、Null、Undefined)不同,會將它們進行數據類型轉化,再進行比較。例如:

0 == ""                                                  // true
0 == "0"                                                 // true
1 == "1"                                                 // true
"0" == ""                                                // false

false == 0                                               // true
false == "0"                                             // true
false == "false"                                         // false
false == null                                            // false
true == null                                             // false
false == undefined                                       // false
true == undefined                                        // false
null == undefined                                        // true
NaN == NaN                                               // false

0 === ""                                                 // false
0 === "0"                                                // false
1 === "1"                                                // false

false === "0"                                            // false
null === undefined                                       // false

[] == false                                              // true
![] == false                                             // true
![] == []                                                // true
![] === []                                               // false

null === document.getElementById("ABC")                  // true(document.getElementById("ABC") 不存在)

2、 基本數據類型與引用數據類型: 將引用數據類型(function、object,其中object包含array)轉化(后臺自動調用 Object.prototype.valueOf() )為它的原始值,再進行比較。例如:

[1,2] == "0"                                            // true
function(){return ["1,2"]}() == "1,2"                   // true

[1,2] === "0"                                           // false
function(){return ["1,2"]}() === "1,2"                  // false

3、 兩個引用類型: 判斷兩者之間的引用路徑。例如:

[1,2] == [1,2]                                          // false
[1,2] === [1,2]                                         // false
總結

1、" == " 情況
一般轉化規則:(對象 => 字符串 => 數字值) 或 (布爾值 => 數字值)
(1)字符串與數字比較時,字符串轉化成數字值,二者再進行比較。
(2)布爾值與數字比較時,布爾值轉化成數字值,二者再進行比較。
(3)字符串與布爾值比較時,二者全部轉化成數字值再進行比較。
(4)對象與數字比較時,對象先轉化成字符串,然后再轉化成數字值,與數字值進行比較。
(5)對象與字符串比較時,對象轉化成字符串,然后二者再進行比較。
(6)對象和布爾值比較時,對象先轉化成字符串,然后再轉化成數字值,布爾值直接轉化為數字,二者再進行比較。
(7)nullundefined 二者相等,不能把二者轉化為其他值,二者與其他值比較返回 false
(8)![] == []。(根據運算符的優先級,! 先執行,直接轉化為布爾值(空字符串,NaN,0,null,undefined 都是 fasle,其余都是 true)再取反,故![] 轉化為 false。其余依照以上規則轉化。最后 0 == 0,故結果為 true。)

2、" === " 情況
(1)兩個值類型不同,就返回 fasle
(2)兩個值都是數值,并且是同一個值,那么為 true,另外:如果其中至少一個是NaN,那么為 fasle。(判斷一個值是否是 NaN,只能使用 isNaN() 來判斷);
(3)兩個值都是字符串,每個位置的字符都一樣,那么 true,否則 fasle
(4)兩個值都引用同一個對象或函數,那么為true;否則 fasle
(5)兩個值都是 truefasle,那么 true,否則 fasle
(6)兩個值都是nullundefined,那么為true;否則 fasle

結論:推薦使用 “===”, 只要類型不一致,直接返回 fasle;“==” 會造成類型轉換再進行比較, 不嚴謹。

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/106318.html

相關文章

  • 我所知道JavaScript之undefinednull區別

    摘要:是全局對象的一個屬性,當聲明了一個變量而未初始化時,得到的就是。作為函數的參數,表示該函數的參數不是對象。作為對象原型鏈的終點。表示缺少值,此處應該有值,但未定義。因此和的值相等而類型不相等。數字運算不相同這是由于約定的不同所決定的。 對于undefined和null我一直知道他們有很多區別,也知道一點關于他們的區別,但卻不具體系統,因此總結了一下,主要心得如下: 我們要區分它們,首先...

    hatlonely 評論0 收藏0
  • Front-end-Developer-Interview-Questions

    摘要:前端工作面試問題備注本包含了一些前端面試問題用于考查候選者。不建議對單個候選者問及每個問題那需要好幾個小時。列舉不同的清除浮動的技巧,并指出它們各自適用的使用場景。選擇器字符串,字符串,回調函數,元素,對象,數組,元素數組,對象等。 https://github.com/darcyclarke/Front-end-Developer-Interview-Questions 前端工作面...

    array_huang 評論0 收藏0
  • Front-end-Developer-Interview-Questions

    摘要:前端工作面試問題備注本包含了一些前端面試問題用于考查候選者。不建議對單個候選者問及每個問題那需要好幾個小時。列舉不同的清除浮動的技巧,并指出它們各自適用的使用場景。選擇器字符串,字符串,回調函數,元素,對象,數組,元素數組,對象等。 https://github.com/darcyclarke/Front-end-Developer-Interview-Questions 前端工作面...

    shadajin 評論0 收藏0
  • Front-end-Developer-Interview-Questions

    摘要:前端工作面試問題備注本包含了一些前端面試問題用于考查候選者。不建議對單個候選者問及每個問題那需要好幾個小時。列舉不同的清除浮動的技巧,并指出它們各自適用的使用場景。選擇器字符串,字符串,回調函數,元素,對象,數組,元素數組,對象等。 https://github.com/darcyclarke/Front-end-Developer-Interview-Questions 前端工作面...

    13651657101 評論0 收藏0
  • JavaScriptMapForEach區別

    摘要:示例下方提供了一個數組,如果我們想將其中的每一個元素翻倍,我們可以使用和來達到目的。注意,是不會返回有意義的值的。允許更改原始數組的元素。自從年雙十一正式上線,累計處理了億錯誤事件,得到了金山軟件等眾多知名用戶的認可。 譯者按: 慣用Haskell的我更愛map。 原文: JavaScript?—?Map vs. ForEach - What’s the difference bet...

    charles_paul 評論0 收藏0
  • undefined與null區別

    摘要:目前,和基本是同義的,只有一些細微的差別。表示沒有對象,即該處不應該有值。作為對象原型鏈的終點。五新增持續更新中一般是意外情況產生的,則是有意為對象賦值來說明這是一個空的對象的返回值是的類型是 摘自阮一峰博客,另附自己的理解分析。 大多數計算機語言,有且僅有一個表示無的值,比如,C語言的NULL,Java語言的null,Python語言的None,Ruby語言的nil。有點奇怪的是,J...

    defcon 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<