详解JavaScript中的Object.is()与"==="运算符总结
作者:杜尼卜 发布时间:2024-04-22 12:50:25
三重相等运算符 === 严格检查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,翻译:公众号《前端全栈开发者》
来源:https://juejin.im/post/5ee9616851882543152d14d8


猜你喜欢
- 概述做日志分析工作的经常需要跟成千上万的日志条目打交道,为了在庞大的数据量中找到特定模式的数据,常常需要编写很多复杂的正则表达式。例如枚举出
- ASP+XML制作菜单管理!menu.asp 这个是前台执行部分<% '----------------
- 新建两张表:表1:student 截图如下:表2:course 截图如下:(此时这样建表只是为了演示连接SQL语句,
- #! /usr/bin/python''' File&n
- 如何在第10000名来访者访问时显示中奖页面?看看下面的代码:< SCRIPT LANGUAGE=VBScript
- 这篇文章主要介绍了Python socket模块ftp传输文件过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学
- 字符串查找基本操作主要分为三个关键词:find()、index()、count()。这三个用法相同,格式都是为:自定义字符串名.关键词(‘子
- 不得不承认,傲游在用户体验方面是做得比较好的,所以它的用户群非常大。也正因为如此,它的某些不好的特性也造成了开发人员不可忽略的浏览器兼容问题
- 代码如下: document.getElementById("btnConnect").value = "连接
- 功能描述数据库间数据同步方式很多,在上篇博文中有总结。本文是用py程序实现数据同步。A数据库中有几十张表,要汇聚到B数据库中,且表结构一致,
- 一、安装pip install pymysql二、连接数据库三种连接数据库的方式import pymysql# 方式一conn = pymy
- 1.什么是labelpandas处理数据时,我们会经常看到dataframe结构使用loc, iloc, ix等方法。那么这些方法到底有啥区
- 写的dht协议搜索的程序,这几天优化了一下发现速度确实快了好多。但是出现了一个新的问题,内存直接飙升,我开了十个爬虫占用内存800m。开始我
- 一、问题描述如题,在使用pip install xxx的方法安装python库,或者是基于python的软件时,报错“E
- xhtml+css页面制作过程中问题的解决方案,说是解决方案应该有点过了,充其量只不过是给刚刚开始学标准页面制作的朋友们的一些小建议,如果讲
- 一般而言,有两种连接sql server 的方式,一是利用 sql server 自带的客户端工具,如企业管理器、查询分析器、事务探查器等;
- Python引入了一个机制:引用计数。引用计数python内部使用引用计数,来保持追踪内存中的对象,Python内部记录了对象有多少个引用,
- Internet的规模每一百天就会增长一倍,客户希望获得7天×24小时的不间断可用性及较快的系统反应时间,而不愿屡次看到某个站点“Serve
- 本文为大家分享了pygame游戏之旅的第6篇,供大家参考,具体内容如下定义一个障碍模型函数:def things(thingx, thing
- 本文实例讲述了js点击事件的执行过程。分享给大家供大家参考,具体如下:js事件对象event包括很多事件类型,这里用onclick事件为例,