每日 30 秒之 difference

52次阅读

共计 975 个字符,预计需要花费 3 分钟才能阅读完成。

简介
根据给出的函数找出两个数组中的差集。
const differenceBy = (a, b, fn) => {
const s = new Set(b.map(fn));
return a.filter(el => !s.has(fn(el)));
};
代码分析
这段代码使用了 ES2015 中定义的 Set 对象。Set 对象的值的特点是不含有重复的值,这个特性可以用来实现对一个数组的去重。
有的同学会问了那为啥要在这把 b 转化为 Set 对象 呢,直接用 Array.prototype.indexOf 不是也可以实现查找数组中的值。实际上 Set.prototype.has 方法的效率会比 Array.prototype.indexOf 高一点。
Set 对象 还有很多有用的方法可以到 MDN web docs 查看。
使用场景
找出两个公司职员中工作不同的职员,这里只是简单模拟一个小场景真实开发中往往会经过更多的判断和归集。
const superHeroCompany = [
{name: ‘xiaoer’, job: ‘ 程序员 ’},
{name: ‘xiaosi’, job: ‘ 图书管理员 ’,},
{name: ‘menty’, job: ‘ 会计 ’},
]

const happyCompany = [
{name: ‘xiaofu’, job: ‘ 程序员 ’},
{name: ‘panghu’, job: ‘ 会计 ’},
]

const diffUsers = differenceBy(superHeroCompany, happyCompany, v => v.job)
相似代码
找出两个数组当中的差集,要注意的是对象的值一样并不是两个对象就相等了,而是对象的指向一样时才会相等。
// 该源码来自于 https://30secondsofcode.org
const difference = (a, b) => {
const s = new Set(b);
return a.filter(x => !s.has(x));
};
根据比较函数 comp 的返回值来过滤两个数组中的差集。
// 该源码来自于 https://30secondsofcode.org
const differenceWith = (arr, val, comp) => arr.filter(a => val.findIndex(b => comp(a, b)) === -1)
打赏 & 联系
如果您感觉有收获,欢迎给我打赏,以激励我输出更多的优质内容。

本文原稿来自 PushMeTop

正文完
 0