我需要减少对象的数组
[
{id:1, value:'A'},
{id:2, value:'B'},
{id:3, value:'B'},
{id:4, value:'B'},
{id:5, value:'A'},
{id:6, value:'A'},
{id:7, value:'B'}
]
至
[
{id:1, value:'A'},
{id:2, value:'B'},
{id:5, value:'A'},
{id:7, value:'B'}
]
如果连续的对象具有相同的值,它将保留第一个对象并删除其余的对象。
我当前的解决方案是
var lastValue = undefined;
var result = [];
var propPath = 'value'; // I need later to reference nested props
objects.filter(function(object){
var value = _.at(object, propPath);
if (!_.isEqual(value, lastValue)){
result.push(object);
lastValue = value;
}
});
console.log(result);
我的问题是,由于Lodash具有许多功能,是否有 Lodash方式可以更简单地执行此操作?也许一些不使用辅助变量(lastValue和结果)的预构建解决方案。
最佳答案
这可以用 .reject
解决:
_.reject(objects, function (object, i) {
return i > 0 && objects[i - 1].value === object.value;
});
DEMO