Lodash Javascript返回基于关闭唯一属性值的元素

时间:2016-03-04 19:33:38

标签: javascript lodash

我正在尝试使用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)并且它不起作用。

2 个答案:

答案 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)

您可以使用_.uniqBy

_.uniqBy(mainThings, function(item) {
    return item.item.id;
});

请参阅this Plnkr