我正在尝试使用lodash,但无法找到一个将采用此功能的javascript函数:
[
{item: {id: 1}, 'name': 'hi'},
{item: {id: 2}, 'name': 'hey'},
{item: {id: 1}, 'name': 'hello'}
];
并将其转换为
[
{item: {id: 1}, 'name': 'hi'},
{item: {id: 2}, 'name': 'hey'}
];
到目前为止,我在javascript中有这个:
var mainThings = [
{item: {id: 1}, 'name': 'hi'},
{item: {id: 2}, 'name': 'hey'},
{item: {id: 1}, 'name': 'hello'}
];
uniqueMainsFunc = function() {
var ids = [],
mains = [];
_.forEach(mainThings, function(thing) {
if (ids.indexOf(thing.item.id) === -1) {
ids.push(thing.item.id);
mains.push(thing);
}
});
return uniqueMains;
};
在这种情况下,uniqueMains只包含:
[
{item: {id: 1}, 'name': 'hi'},
{item: {id: 2}, 'name': 'hey'}
]
是否有可以更好地处理此问题的lodash功能? 在.forEach之后我尝试使用!_。some(uniqueNestedIds,thing.item.id)并且它不起作用。
答案 0 :(得分:2)
uniqBy方法可以解决您的问题
var mainThings = [
{ item: { id: 1 }, 'name': 'hi' },
{ item: { id: 2 }, 'name': 'hey' },
{ item: { id: 1 }, 'name': 'hello' }
];
var uniq = _.uniqBy(mainThings, 'item.id')
console.log(uniq);
结果:
[ { item: { id: 1 }, name: 'hi' },
{ item: { id: 2 }, name: 'hey' } ]
答案 1 :(得分:2)