成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

JS 中 == 不檢查類型?不,你錯了!

開發 前端
根據 JavaScript 規范參考 ECMAScript 262 文檔,概述了 IsLooselyEqual算法 ,負責處理“==”操作。這里說明了涉及 14 個步驟的綜合過程。值得注意的是,這個過程大量涉及類型檢查,如涉及Type(x)的初始步驟所證明的那樣,并引入強制作為整個操作的重要方式。

Hello,大家好,我是 Sunday。

我們知道在 JS 中有兩種判斷相等的方式,即:== 和 ===。并且很多同學會認為“==”運算符(通常稱為“松散相等”或簡稱“相等”)是不精準的。

“==”不關心數據類型,只關心值。

例如如下代碼:

1 == '1' // true

而“===”運算符,即“嚴格相等”,可以有效地驗證操作數的值和類型:

1 === '1' // false

但是這種理解真的是完全正確的嗎?最近有一個同學在面試的時候被深入問到了這個問題,咱們來看一下:

“==”和“===” 的執行邏輯

先說結論,其實:“==”和“===”這兩個運算符都優先考慮數據類型,并在執行各自的算法之前執行類型檢查。事實上,即使是“==”運算符在評估值之前也會驗證類型。

根據 JavaScript 規范參考 ECMAScript 262 文檔,概述了 IsLooselyEqual算法 ,負責處理“==”操作。這里說明了涉及 14 個步驟的綜合過程。值得注意的是,這個過程大量涉及類型檢查,如涉及Type(x)的初始步驟所證明的那樣,并引入強制作為整個操作的重要方式。

圖片圖片

下方描述為翻譯后的結果:

// 在線地址:https://262.ecma-international.org/14.0/?_gl=1*1ddd25w*_ga*MTAzMTk1MjUwNS4xNzA0MTgwNDk0*_ga_TDCK4DWEPP*MTcwNDE4MDQ5NC4xLjAuMTcwNDE4MDQ5NC4wLjAuMA..&_ga=2.72864531.1838071013.1704180495-1031952505.1704180494#sec-islooselyequal

7.2.14 松散相等 ( x, y )
抽象操作 IsLooselyEqual 接受參數 x(ECMAScript 語言值)和 y(ECMAScript 語言值),并返回包含布爾值的正常完成或拋出完成。 它提供 == 運算符的語義。 調用時它執行以下步驟:

1. 如果 Type(x) 是 Type(y),則
A。 A。 返回 IsStrictlyEqual(x, y)。
2. 如果 x 為 null 并且 y 未定義,則返回 true。
3. 如果 x 未定義且 y 為 null,則返回 true。
4. 注意:此步驟已在 B.3.6.2 節中替換。
5. 如果 x 是數字且 y 是字符串,則返回! IsLooselyEqual(x, !ToNumber(y))。
6. 如果 x 是字符串且 y 是數字,則返回! IsLooselyEqual(!ToNumber(x), y)。
7. 如果 x 是 BigInt 并且 y 是 String,則
A。 令 n 為 StringToBigInt(y)。
b. 如果 n 未定義,則返回 false。
C。 返回 ! IsLooselyEqual(x, n)。
8. 如果 x 是 String 并且 y 是 BigInt,則返回! IsLooselyEqual(y, x)。
9. 如果 x 是布爾值,則返回! IsLooselyEqual(!ToNumber(x), y)。
10. 如果 y 是布爾值,則返回! IsLooselyEqual(x, !ToNumber(y))。
11. 如果 x 是字符串、數字、BigInt 或符號并且 y 是對象,則返回! IsLooselyEqual(x, ? ToPrimitive(y))。
12. 如果 x 是對象并且 y 是字符串、數字、BigInt 或符號,則返回! IsLooselyEqual(? ToPrimitive(x), y)。
13. 如果 x 是 BigInt 并且 y 是 Number,或者如果 x 是 Number 并且 y 是 BigInt,則
A。 A。 如果 x 不是有限的或 y 不是有限的,則返回 false。
b. b. 如果 ?(x) = ?(y),則返回 true; 否則返回 false。
14. 返回 false。

強制轉換涉及將一種類型的值轉換為另一種類型,可以通過有意操作顯式轉換,也可以通過 JavaScript 機制隱式轉換,無需任何用戶干預。

另外一個有趣的方法,當兩種類型匹配時,將使用 IsStrictlyEqual 算法(步驟 1.a),該算法與“===”運算符使用的算法完全相同。

圖片圖片

翻譯之后為:

// 在線地址:https://262.ecma-international.org/14.0/?_gl=1*1ddd25w*_ga*MTAzMTk1MjUwNS4xNzA0MTgwNDk0*_ga_TDCK4DWEPP*MTcwNDE4MDQ5NC4xLjAuMTcwNDE4MDQ5NC4wLjAuMA..&_ga=2.72864531.1838071013.1704180495-1031952505.1704180494#sec-isstrictlyequal

7.2.15 IsStrictlyEqual(x,y)
抽象操作 IsStrictlyEqual 接受參數 x(ECMAScript 語言值)和 y(ECMAScript 語言值)并返回布爾值。 它提供 === 運算符的語義。 調用時它執行以下步驟:

1. 如果 Type(x) 不是 Type(y),則返回 false。
2. 如果 x 是一個數字,那么
A。 返回 Number::equal(x, y)。
3. 返回 SameValueNonNumber(x, y)。

讓我們深入研究 IsLooselyEqual的第五步(如果 x 是數字且 y 是字符串,則返回! IsLooselyEqual(x, !ToNumber(y))):

圖片圖片

根據提供的代碼片段:

1 == "1"  // true 
// x 是數字 (1) 
// y 是字符串 ("1")

此處,調用 ToNumber (y)函數時會發生隱式 強制轉換。此強制過程將值(y,即“1”)從其原始類型(在本例中為String)轉換為不同的類型(在本例中為Number)。在比較值之前,此步驟涉及類型檢查和強制,將兩個值對齊到同一類型(Number),從而實現兩個數字之間的直接比較。

1 == "1"  // true 

//步驟 1。
// -> 檢查兩種類型
// -> 兩種類型不同
// -> 執行 IsLooselyEqual 的后續步驟

//步驟 2。   
// -> "1 " (String) 將變成 1 (Number) - 強制機制

//Step 3.   
// -> 將值 1(數字,從左側)與值 1(數字,在右側)進行比較

在這種情況下,嚴格相等運算符將返回 false,如前面提供的內容所示。由于兩種類型不同,因此 === 會判定為 false:

1 === "1"  // false 

//步驟 1.   
// -> 檢查兩種類型
// -> 兩種類型不同
// -> 結束進程,返回 false

總結

兩個比較運算符都會檢查類型,但松散的相等運算符(==) 需要執行額外的步驟。

  • 它首先檢查比較值的類型,如果它們不同,則將它們對齊到相同類型(使用隱式強制)。
  • 然后繼續進行值比較。 使用嚴格相等運算符(===)時,不涉及該額外步驟。在值不同的情況下,它直接返回 false。
責任編輯:武曉燕 來源: 程序員Sunday
相關推薦

2023-11-04 16:26:18

C語言數組

2022-05-24 08:31:05

C語言檢查數組

2018-08-22 06:56:55

物聯網商業模式IOT

2024-11-14 11:39:10

Order注解接口

2023-01-05 08:09:27

GroovyDSL?

2019-09-08 15:43:19

UbuntuLinuxIP地址

2022-03-28 11:06:38

Nacos監聽配置

2023-06-13 18:24:26

TypeScriptJSDoc開發

2021-08-11 15:13:54

數字化

2021-01-28 07:52:39

JS數組變量

2013-07-09 14:41:58

C動態類型

2016-04-01 10:08:33

youtubeappuber

2022-04-26 06:43:12

文檔TCPLinux

2021-11-12 05:33:45

WiFi輻射無線路由器

2023-01-06 08:06:52

Groovy類型擴展

2011-07-11 14:36:05

JAVA

2024-01-05 07:46:15

JS克隆對象JSON

2023-06-14 07:23:57

打印文檔打印機

2019-10-31 10:25:19

算法Java數據結構

2021-06-09 07:55:19

Typescript類型檢查
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美成人免费电影 | 日韩av在线中文字幕 | 亚洲成人精品 | 黑人精品xxx一区一二区 | 九九精品影院 | 男女污污动态图 | av网站在线免费观看 | 日本不卡一区二区三区在线观看 | 亚洲欧美日韩在线 | 亚洲午夜三级 | 欧美日韩电影一区二区 | 激情福利视频 | 精品久久久久久久久久 | 成人乱人乱一区二区三区软件 | 国产成人免费视频网站高清观看视频 | 欧美日韩专区 | 国产在线一区二区三区 | 日韩精品一二三 | 在线观看黄色大片 | 久久久久久久亚洲精品 | 欧美国产91 | 91欧美 | 国产精品自产av一区二区三区 | 免费久久99精品国产婷婷六月 | www久久久 | 成人永久免费 | 黄色片网站在线观看 | 91黄色片免费看 | 国产小视频精品 | 久久国产欧美日韩精品 | 中文字幕二区 | 亚洲欧美一区二区三区在线 | 欧美成人精品一区二区三区 | 亚洲国产aⅴ精品一区二区 免费观看av | 久久久久久亚洲精品 | 成人精品一区二区三区中文字幕 | av一二三区 | 999免费视频 | 久久久久精 | 精品国产乱码一区二区三 | 欧美日韩亚洲在线 |