前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【点滴】JavaScript中的 Object.is() 与 === 运算符有什么区别?

【点滴】JavaScript中的 Object.is() 与 === 运算符有什么区别?

作者头像
疯狂的技术宅
发布2021-03-16 11:17:57
3320
发布2021-03-16 11:17:57
举报
文章被收录于专栏:京程一灯京程一灯

前端点滴front-end tips


  • 分类:JavaScript | Object, Type

如果要检查 JavaScript 中的相等性,有两个比较运算符:双等号运算符(==)和三等号运算符(===)。

简而言之,双等号运算符(==)仅仅比较值,而三等号运算符(===)可以比较值和类型。但是还有第三个选项 Object.is(),除了 NaN+0-0 之外,其行为与三等号于运算符相同。

以下是一些例子,可进一步明确说明:

代码语言:javascript
复制
{} === {}; // false
Object.is({}, {}); // false

1 === 1; // false
Object.is(1, 1); // false

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

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

以下代码是在 ES5 中模拟实现的Object.is

代码语言:javascript
复制
Object.defineProperty(Object, 'is', {
  value: function(x, y) {
    if (x === y) {
      // 针对+0 不等于 -0的情况
      return x !== 0 || 1 / x === 1 / y;
    }
    // 针对NaN的情况
    return x !== x && y !== y;
  },
  configurable: true,
  enumerable: false,
  writable: true
});
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2021-03-12,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 前端先锋 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档