自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

JavaScript中的Object.is()與嚴格相等運算符

開發(fā) 前端
ES2015規(guī)范引入了 Object.is(),其行為與嚴格的相等運算符幾乎相同。什么時候使用 Object.is() 代替嚴格的相等性檢查?讓我們找出答案。

三重相等運算符 === 嚴格檢查2個值是否相同:

  1. 1 === 1;    // => true 
  2. 1 === '1';  // => false 
  3. 1 === true; // => false 

但是,ES2015規(guī)范引入了 Object.is(),其行為與嚴格的相等運算符幾乎相同:

  1. Object.is(1, 1);    // => true 
  2. Object.is(1, '1');  // => false 
  3. Object.is(1, true); // => false 

主要問題是:什么時候使用 Object.is() 代替嚴格的相等性檢查?讓我們找出答案。

1. 嚴格相等檢查操作符

首先,讓我們快速回顧一下嚴格的相等運算符是如何工作的。

當兩個值的類型相同且持有相同的值時,嚴格相等檢查運算符的計算結果為 true。

例如,以下原始值是相等的,因為它們是相同的類型且具有相同的值:

  1. 1         === 1;         // => true 
  2. 'abc'     === 'abc';     // => true 
  3. true      === true;      // => true 
  4. null      === null;      // => true 
  5. undefined === undefined; // => true 

嚴格相等運算符不執(zhí)行類型的強制轉換,即使操作符持有合理的相同值,但是不同類型的操作符,它們也不是嚴格相等的:

  1. 1    === '1';       // => false 
  2. 1    === true;      // => false 
  3. null === undefined; // => false 

對對象執(zhí)行嚴格相等檢查時,對象僅與自身嚴格相等:

  1. const myObject = { prop: 'Value' }; 
  2. myObject === myObject;  // => true 

即使2個對象的屬性和值完全相同,它們的值也不同:

  1. const myObject1 = { prop: 'Value' }; 
  2. const myObject2 = { prop: 'Value' }; 
  3. myObject1 === myObject2; // => false 

以上比較方案在 Object.is(valueA,valueB) 中的工作原理完全相同。

嚴格相等檢查和 Object.is() 之間的區(qū)別在于,如何處理 NaN 和如何處理負零 -0。

首先,NaN(非數(shù)字)并不嚴格等于任何其他值,即使使用另一個 NaN:

  1. NaN === NaN; // => false 
  2. NaN === 1;   // => false 

其次,嚴格相等運算符不能將 -0 與 +0 區(qū)分開:

  1. -0 === +0; // => true 

嚴格相等運算符使用嚴格相等比較算法。

http://www.ecma-international.org/ecma-262/7.0/index.html#

sec-strict-equality-comparison

2. Object.is()

Object.is(valueA,valueB) 以與嚴格相等運算符相同的方式檢查相等性的參數(shù),但有兩個區(qū)別。

首先,NaN 等于另一個 NaN 值:

  1. Object.is(NaN, NaN); // => true 
  2. Object.is(NaN, 1);   // => false 

其次,Object.is() 區(qū)分 -0 和 +0:

  1. Object.is(-0, +0); // => false 

與嚴格相等運算符相比,Object.is() 使用相同值比較算法。

http://www.ecma-international.org/ecma-262/7.0/index.html#sec-samevalue

總結

在大多數(shù)情況下,嚴格相等運算符是比較值的好方法。

如果你想直接檢查 NaN 值或對負零和正零進行更嚴格的區(qū)分,那么 Object.is() 是一個不錯的選擇。

Object.is() 作為比較值的函數(shù)性方法也很有用,例如在函數(shù)式編程中。

 

責任編輯:趙寧寧 來源: 今日頭條
相關推薦

2021-03-13 17:48:07

JavaScriptObject.is()運算符

2021-05-07 06:27:29

JavaScript運算符開發(fā)

2022-09-07 00:04:37

JavaScript運算符技巧

2009-11-06 13:57:52

C#

2023-04-10 08:58:13

C#關系運算符

2021-02-20 23:34:22

JavaScript運算符開發(fā)

2017-05-11 16:38:07

javascript邏輯運算符

2020-03-27 22:33:30

JavaScript運算符逗號

2023-09-07 23:30:47

運算符C++

2025-02-24 11:16:20

2021-07-12 15:35:56

JavaScript代碼運算符

2017-09-05 16:17:35

JavaScript運算轉換

2017-09-13 10:58:51

JavaScript轉換規(guī)則

2024-06-11 14:57:00

2025-03-05 09:37:03

2009-08-11 15:51:08

C#運算符算術運算符

2020-10-15 08:11:56

JavaScript邏輯運算符

2009-08-12 15:02:49

C#賦值運算符簡單賦值運算符

2009-08-12 15:20:18

C#賦值運算符復合賦值運算符

2010-10-08 09:17:07

JavaScript表JavaScript運
點贊
收藏

51CTO技術棧公眾號