三重相等运算符 === 严格检查2个值是否相同:
1 === 1; // => true 1 === '1'; // => false 1 === true; // => false
但是,ES2015规范引入了 Object.is(),其行为与严格的相等运算符几乎相同:
Object.is(1, 1); // => true Object.is(1, '1'); // => false Object.is(1, true); // => false
主要问题是:什么时候使用 Object.is() 代替严格的相等性检查?让我们找出答案。
1.严格相等检查操作符
首先,让我们快速回顾一下严格的相等运算符是如何工作的。
当两个值的类型相同且持有相同的值时,严格相等检查运算符的计算结果为 true。
例如,以下原始值是相等的,因为它们是相同的类型且具有相同的值:
1 === 1; // => true 'abc' === 'abc'; // => true true === true; // => true null === null; // => true undefined === undefined; // => true
严格相等运算符不执行类型的强制转换,即使操作符持有合理的相同值,但是不同类型的操作符,它们也不是严格相等的:
1 === '1'; // => false 1 === true; // => false null === undefined; // => false
对对象执行严格相等检查时,对象仅与自身严格相等:
const myObject = { prop: 'Value' }; myObject === myObject; // => true
即使2个对象的属性和值完全相同,它们的值也不同:
const myObject1 = { prop: 'Value' }; const myObject2 = { prop: 'Value' }; myObject1 === myObject2; // => false
以上比较方案在 Object.is(valueA,valueB) 中的工作原理完全相同。
严格相等检查和 Object.is() 之间的区别在于,如何处理 NaN 和如何处理负零 -0。
首先,NaN(非数字)并不严格等于任何其他值,即使使用另一个 NaN:
NaN === NaN; // => false NaN === 1; // => false
其次,严格相等运算符不能将 -0 与 +0 区分开:
-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) 以与严格相等运算符相同的方式检查相等性的参数,但有两个区别。
首先,NaN 等于另一个 NaN 值:
Object.is(NaN, NaN); // => true Object.is(NaN, 1); // => false
其次,Object.is() 区分 -0 和 +0:
Object.is(-0, +0); // => false
与严格相等运算符相比,Object.is() 使用相同值比较算法。http://www.ecma-international.org/ecma-262/7.0/index.html#sec-samevalue
总结
在大多数情况下,严格相等运算符是比较值的好方法。
如果你想直接检查 NaN 值或对负零和正零进行更严格的区分,那么 Object.is() 是一个不错的选择。
Object.is() 作为比较值的函数性方法也很有用,例如在函数式编程中。
来源:dmitripavlutin.com,作者:Dmitri Pavlutin,翻译:公众号《前端全栈开发者》
到此这篇关于详解JavaScript中的Object.is()与"==="运算符总结的文章就介绍到这了,更多相关JavaScript中的Object.is()与"==="运算符内容请搜索小牛知识库以前的文章或继续浏览下面的相关文章希望大家以后多多支持小牛知识库!
本文向大家介绍JavaScript的==运算详解,包括了JavaScript的==运算详解的使用技巧和注意事项,需要的朋友参考一下 大家知道,JavaScript中的==是一种比较复杂运算,它的运算规则很奇怪,很容易让人犯错,从而成为JavaScript中“最糟糕的特性”之一。 在仔细阅读ECMAScript规范的基础上,我画了一张图,我想等你理解了这张图后,会彻底地弄懂关于==运算的一切。同时,
本文向大家介绍JavaScript中的6种运算符总结,包括了JavaScript中的6种运算符总结的使用技巧和注意事项,需要的朋友参考一下 JavaScript 运算符主要包括: 算术运算符 赋值运算符 比较运算符 三元运算符 逻辑运算符 字符串连接运算符 算术运算符 运算符 说明 例子 运算结果 + 加 y = 2+1 y = 3 - 减 y = 2-1 y = 1 * 乘 y = 2*3 y
本文向大家介绍详解JavaScript逻辑And运算符,包括了详解JavaScript逻辑And运算符的使用技巧和注意事项,需要的朋友参考一下 在JavaScript中,逻辑 AND 运算符用双和号(&&)表示 下面的真值表描述了逻辑AND运算符的行为: 需要说明的是:逻辑AND运算的运算数可以是任何类型的,不止是Boolean值,如果某个运算数不是原始的Boolean型值,逻辑AND运算并不
本文向大家介绍详解JavaScript逻辑Not运算符,包括了详解JavaScript逻辑Not运算符的使用技巧和注意事项,需要的朋友参考一下 在JavaScript 中,逻辑NOT运算符与C和Java中的逻辑 NOT 运算符相同,都由感叹号(!)表示。与逻辑 OR 和逻辑 AND 运算符不同的是,逻辑 NOT 运算符返回的一定是 Boolean 值。 逻辑 NOT 运算符的行为如下: 如果运算数
本文向大家介绍JavaScript知识点总结(四)之逻辑OR运算符详解,包括了JavaScript知识点总结(四)之逻辑OR运算符详解的使用技巧和注意事项,需要的朋友参考一下 在JavaScript中,逻辑OR运算符用||表示 下面的真值表描述了逻辑AND运算符的行为: 在JavaScript中,0,"",false,null,undefined,NaN均表示false, 可以用如下的代码证明
本文向大家介绍Javascript实现运算符重载详解,包括了Javascript实现运算符重载详解的使用技巧和注意事项,需要的朋友参考一下 最近要做数据处理,自定义了一些数据结构,比如Mat,Vector,Point之类的,对于加减乘除之类的四则运算还要重复定义,代码显得不是很直观,javascript没有运算符重载这个像C++、C#之类的功能的确令人不爽,于是想“曲线救国”,自动将翻译代码实现运