如何过滤掉对象数组的重复项

时间:2016-01-09 20:13:48

标签: javascript angularjs

我有一个对象数组,如下所示:

$scope.SACCodes = [
    {'code':'023', 'description':'Spread FTGs', 'group':'footings'},
    {'code':'024', 'description':'Mat FTGs', 'group':'footings'},
    {'code':'025', 'description':'CONT. FTGs', 'group':'footings'},
    {'code':'025', 'description':'CONT. FTGs', 'group':'levels'},
    {'code':'023', 'description':'Trucks', 'group':'footings'}
]

我需要过滤掉codegroup重复的重复项。如果只有其中一个是相同的,则不应过滤掉它。

3 个答案:

答案 0 :(得分:1)

这使用帮助器哈希来记录已经处理了codegroup的哪种组合。只有当它找到迄今为止未使用的组合时才会将其添加到retVal数组;

function dedup() {
    var dups = {};
    var retVal = [];

    for (var i = 0; i < $scope.SACCodes.length; i++) {
       var sCode = $scope.SACCodes[i];
       var key = sCode.code +'/'+ sCode.group;
       if (!dups[key]) {
          retVal.push (sCode);
          dups[key] = sCode;
       }
    }
    return retVal;
}

See working example

未来几年,您可以使用Object.values(dups);代替retVal,从而缩短代码。

答案 1 :(得分:1)

以下是另一种基于TLindig's answer to a similar question的方法。

向范围添加过滤方法:

$scope.onlyUnique = function(value, index, self) { 
  codes = self.map(function(c) {return c.code});
  groups = self.map(function(c) {return c.group});
  return codes.indexOf(value.code) === index || groups.indexOf(value.group) === index;

在ng-repeat中或您想要唯一值的位置调用filter方法:

<div ng-repeat="c in SACCodes.filter(onlyUnique)">code: {{c.code}} desc: {{c.description}} group: {{c.group}}</div>

输出:

code: 023 desc: Spread FTGs group: footings
code: 024 desc: Mat FTGs group: footings
code: 025 desc: CONT. FTGs group: footings
code: 025 desc: CONT. FTGs group: levels

答案 2 :(得分:1)

ES6方式。

var m = new Map();

SACCodes.forEach ( function( item ) {
    var key = item.code + item.group;
    if ( !m.has( key ) ){
        m.set( key, item );
    }
});
SACCodes= [ ...m.values() ];