每日 30 秒之 终极等于

简介

科学家发现,人脑中会分泌多种能让人感到快乐、安全和成就感的物质,这些物质统称为“快乐素”。通常情况下,快乐素的释放水平很低,维持我们心情平静。只有当我们完成了预设目标,作为奖励,大脑才会增加快乐素的分泌,让人感受到满足和成功的喜悦。

这是之前看到的一篇关于 大脑奖励机制 文章的一段话,为了要获得奖励我们需要有预设目标,而是每日 30 秒系列也是为了帮助大家设立一个目标,每日完成一小段代码的学习来实现 对学习上瘾

到了周末发现大家相比起工作日的学习欲望下降得较快,昨天又刚好更新了一个需要花费时间且值得阅读的 每日 30 秒之 巧用可视区域 希望大家有时间可以看看。那今天学习一段比较简单和常用的代码片段来奖励一下大脑 🧠。

在开发中我们最最最最经常用到的一个功能就是 等于,在 JavaScript 中拥有 ===(全等于)==(等于)再加上 JavaScript 是弱类型直接使用 == 会被解释器所转换,转换的规则浮渣且难以记忆这也是各种 == 相关文章层出不穷的原因。在 《JavaScript 语言精粹》== 被归类到了糟粕附录中且建议我们请始终使用 ===!==,更加规范的开发也有利于 BUG 的减少这也是 TypeScript 语言出现的原因之一。

但是 ===!== 也不是万能的当遇上 ObjectArray 时就会吃瘪了,因为它们虽然数据一样但是对应这地址不一样这点在开发过程中要小心。爱思考的同学肯定不甘心于小心和谨防掉入坑中,那让我们一起写一个 终极等于

const equals = (a, b) => {
  if (a === b) return true;
  if (a instanceof Date && b instanceof Date) return a.getTime() === b.getTime();
  if (!a || !b || (typeof a !== 'object' && typeof b !== 'object')) return a === b;
  if (a.prototype !== b.prototype) return false;
  if (Array.isArray(a) && Array.isArray(b)) (a.sort(), b.sort());

  let keys = Object.keys(a);
  if (keys.length !== Object.keys(b).length) return false;
  return keys.every(k => equals(a[k], b[k]));
};

代码分析

首当其冲当然是利用 === 来完成最基础判断:

if (a === b) return true;

当传入 Date 对象是先对两者类型进行判断,再利用 Date.prototype.getTime() 来比较对应的时间是否相等:

if (a instanceof Date && b instanceof Date) return a.getTime() === b.getTime();

当 a 和 b 为 null 或者 undefinded 等非正值时对两者进行比较并过滤掉对象类型,这里也包含了在 a === b 遗留下来不相等值:

if (!a || !b || (typeof a !== 'object' && typeof b !== 'object')) return a === b;

由于剩下来的便是 ObjectArray 类型的数据且 Array 算是特殊的 Object 需要进行递归遍历数据,可以利用原型链来减少递归层数:

if (a.prototype !== b.prototype) return false;

如果两个值都是数组则对他们进行排序,不然由于 Array 是特殊的 Object 被当做 Object 遍历时会因为顺序问题而出现判断错误:

if (Array.isArray(a) && Array.isArray(b)) (a.sort(), b.sort());

如果两个值相等那他们的键值肯定也相等,这里对 length 的判断可以直接先验证长度是否一致。

let keys = Object.keys(a);
if (keys.length !== Object.keys(b).length) return false;
return keys.every(k => equals(a[k], b[k]));

最后只需要利用其中一个的键值数组 和 every 来进行遍历全等判断,更多相关的用法可以看 每日 30 秒之 数组所有数据是否满足某条件 这篇文章。

return keys.every(k => equals(a[k], b[k]));

小扩展:为什么不直接判断他们的长度是否相等呢?

有的眼尖的同学肯定发现了这个问题,这就不得不提一个很经典的例子:

var myObject = new Object();
myObject["firstname"] = "Gareth";
myObject["lastname"] = "Simpson";
myObject["age"] = 21;

console.log(myObject.length); // 输出 undefined

当出现这种情况的时候我们可以利用 Object.prototype.size() 或者 Object.keys(obj).length 来获取它的长度。

使用场景

这里就简单举几个例子:

equals(null, null)  // 输出 true
equals(null, undefined) // 输出 false
equals([1, 2, 3], [3, 2, 1]); // 输出 true
equals([1, 2, 3], [1, 2, 3]); // 输出 true
equals({ i: 'love u' }, { i: 'love u' }); // 输出 true

打赏&联系

如果您感觉有收获,欢迎给我打赏,以激励我输出更多的优质内容。

打赏&联系

本文原稿来自 PushMeTop

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352

推荐阅读更多精彩内容