[英]Javascript return array from 2 arrays removing duplicates
搜索和尝试,到目前为止没有运气。
var newUsers = [{name: 'rich', id: 25}, {name: 'lauren', id: 35}, {name: 'dave', id: 28} ]
var likedUsers = [{name: 'derek', id: 39}, {name: 'rich', id: 25}, {name: 'brian', id: 38} ]
我想要的是:
var leftUsers = [{name: 'lauren', id: 35}, {name: 'dave', id: 28} ]
基本上没有rich
对象,因为这是重复的。 我只关心id
键。
我试过了:
newUsers.forEach((nUser) => {
likedUsers.forEach((lUser) => {
if (nUser.id !== lUser.id){
leftUsers.push(nUser)
}
})
})
但显然这不会起作用,因为只要它们不匹配就会将它们全部添加。
如果可能的话,想要使用forEach / map / filter的es6解决方案
谢谢
使用array.prototype.filter
过滤掉likedUsers
和array.prototype.findIndex
中存在的项以检查是否存在,它应该是:
var newUsers = [{name: 'rich', id: 25}, {name: 'lauren', id: 35}, {name: 'dave', id: 28} ]; var likedUsers = [{name: 'derek', id: 39}, {name: 'rich', id: 25}, {name: 'brian', id: 38} ]; var leftUsers = newUsers.filter(u => likedUsers.findIndex(lu => lu.id === u.id) === -1); console.log(leftUsers);
您可以使用filter()
和some()
方法执行此操作。
var newUsers = [{name: 'rich', id: 25}, {name: 'lauren', id: 35}, {name: 'dave', id: 28} ] var likedUsers = [{name: 'derek', id: 39}, {name: 'rich', id: 25}, {name: 'brian', id: 38} ] const result = newUsers.filter(e => !likedUsers.some(a => a.id == e.id)); console.log(result)
var newUsers = [{name: 'rich', id: 25}, {name: 'lauren', id: 35}, {name: 'dave', id: 28} ]; var likedUsers = [{name: 'derek', id: 39}, {name: 'rich', id: 25}, {name: 'brian', id: 38} ]; var leftusers = newUsers.filter( item => !likedUsers.find(item2 => item.id == item2.id)); console.log(leftusers);
您可以创建在likedUsers
中找到的一组 ID,并通过检查ID是否在Set中来过滤 newUsers
:
const newUsers = [{name: 'rich', id: 25}, {name: 'lauren', id: 35}, {name: 'dave', id: 28} ] const likedUsers = [{name: 'derek', id: 39}, {name: 'rich', id: 25}, {name: 'brian', id: 38} ] const result = newUsers.filter(function({ id }) { return !this.has(id) // take all users which ids is not found in the set }, new Set(likedUsers.map(({ id }) => id))) // create a set of ids in likedUsers and assign to this console.log(result)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.