详解JavaScript中的Object.is()与"==="运算符总结


Posted in Javascript onJune 17, 2020

三重相等运算符 === 严格检查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 相关文章推荐
js实现ASP分页函数 HTML分页函数
Sep 22 Javascript
ExtJs Excel导出并下载IIS服务器端遇到的问题
Sep 16 Javascript
Javascript实现的常用算法(如冒泡、快速、鸽巢、奇偶等)
Apr 29 Javascript
jQuery+PHP打造滑动开关效果
Dec 16 Javascript
jQuery中noconflict函数的实现原理分解
Feb 03 Javascript
JavaScript+CSS实现的可折叠二级菜单实例
Feb 29 Javascript
Node.JS中事件轮询(Event Loop)的解析
Feb 25 Javascript
使用express+multer实现node中的图片上传功能
Feb 02 Javascript
vue在手机中通过本机IP地址访问webApp的方法
Aug 15 Javascript
浅谈vue项目4rs vue-router上线后history模式遇到的坑
Sep 27 Javascript
React冒泡和阻止冒泡的应用详解
Aug 18 Javascript
快速解决vue2+vue-cli3项目ie兼容的问题
Nov 17 Vue.js
vue-iview动态新增和删除的方法
Jun 17 #Javascript
vue iview实现动态新增和删除
Jun 17 #Javascript
vue如何搭建多页面多系统应用
Jun 17 #Javascript
vue2.0实现列表数据增加和删除
Jun 17 #Javascript
使用next.js开发网址缩短服务的方法
Jun 17 #Javascript
vue实现前端分页完整代码
Jun 17 #Javascript
JS实现网站楼层导航效果代码实例
Jun 16 #Javascript
You might like
如何用php生成扭曲及旋转的验证码图片
2013/06/07 PHP
thinkphp路由规则使用示例详解和伪静态功能实现(apache重写)
2014/02/24 PHP
Laravel 5 框架入门(四)完结篇
2015/04/09 PHP
详解PHP的Yii框架中组件行为的属性注入和方法注入
2016/03/18 PHP
thinkPHP实现MemCache分布式缓存功能
2016/03/23 PHP
PHP正则表达式匹配替换与分割功能实例浅析
2017/02/04 PHP
javascript函数库-集合框架
2007/04/27 Javascript
深入理解JavaScript系列(12) 变量对象(Variable Object)
2012/01/16 Javascript
判断输入是否为空,获得输入类型的JS代码
2013/10/30 Javascript
Jquery搜索父元素操作方法
2015/02/10 Javascript
动态加载js的方法汇总
2015/02/13 Javascript
jquery实现仿新浪微博评论滚动效果
2015/08/06 Javascript
Jquery1.9.1源码分析系列(六)延时对象应用之jQuery.ready
2015/11/24 Javascript
浅谈如何实现easyui的datebox格式化
2016/06/12 Javascript
下一代Bootstrap的5个特点 超酷炫!
2016/06/17 Javascript
EasyUI Datebox 日期验证之开始日期小于结束时间
2017/05/19 Javascript
Vue封装的组件全局注册并引用
2019/07/24 Javascript
Vue 实现可视化拖拽页面编辑器
2021/02/01 Vue.js
go和python调用其它程序并得到程序输出
2014/02/10 Python
给Python IDLE加上自动补全和历史功能
2014/11/30 Python
python实现三维拟合的方法
2018/12/29 Python
python实现比较类的两个instance(对象)是否相等的方法分析
2019/06/26 Python
Django静态资源部署404问题解决方案
2020/05/11 Python
css3使网页、图片变成灰色兼容大多数浏览器
2014/07/02 HTML / CSS
css3实现二维码扫描特效的示例
2020/10/29 HTML / CSS
美国派对用品及装饰品网上商店:Shindigz
2016/07/30 全球购物
Lookfantastic挪威官网:英国知名美妆购物网站
2017/07/26 全球购物
DC Shoes澳大利亚官方网上商店:购买DC鞋子
2019/10/25 全球购物
俄罗斯一家时尚女装商店:Charuel
2019/12/04 全球购物
幼师专业毕业生自荐信
2013/09/29 职场文书
航海技术专业毕业生求职信
2014/04/06 职场文书
出国签证在职证明
2014/09/20 职场文书
安全生产工作汇报材料
2014/10/28 职场文书
介绍信的写法
2015/01/31 职场文书
Mysql数据库命令大全
2021/05/26 MySQL
浅谈Python从全局与局部变量到装饰器的相关知识
2021/06/21 Python