Angularjs 将包含相同键/值的对象与LoDash合并

Angularjs 将包含相同键/值的对象与LoDash合并,angularjs,arrays,lodash,Angularjs,Arrays,Lodash,在对初始数组中的LoDash执行一些操作后,我最终得到以下结果: [ {number:3, product:'apple'}, {number:2, product:'apple'}, {number:4, product:'pear'} ] 我如何操纵它,最终得到: [ {number:5, product:'apple'}, {number:4, product:'pear'} ] 这是原始代码,以防万一: $scope.data = [ { date:'

在对初始数组中的LoDash执行一些操作后,我最终得到以下结果:

[
  {number:3, product:'apple'},
  {number:2, product:'apple'},
  {number:4, product:'pear'}
]
我如何操纵它,最终得到:

[
  {number:5, product:'apple'},
  {number:4, product:'pear'}
]
这是原始代码,以防万一:

$scope.data = [
  {
    date:'date',
    products: [
      {
        number: 3,
        product: 'Apple'
      },
      {
        number: 4,
        product: 'Pear'
      }
    ]
  },
  {
    date:'date',
    products: [
      {
        number: 2,
        product: 'Apple'
      }
    ]
  }
]


const grouped = _.groupBy($scope.data, function(el){
  return moment(el.date).format('dddd, D [de] MMMM');
});

const result = _.map(grouped, (value, date) => ({
    date: date,
    products: _.flatMap(value, el => el.products)
}));

您必须按产品添加单独的分组,这与按日期分组非常相似

// Function for grouping unique products with sum of units
function sumProductsUnits(products) {
    var productGroups = _.groupBy(products, productObj => productObj.product);

    return _.map(productGroups, (productGroup, productName) => ({
        product: productName,
        units: productGroup.reduce((sum, val) => sum + val.number, 0)
    }))
}
用法如下:

const result = _.map(grouped, (value, date) => ({
    date: date,
    products: sumProductsUnits(
        _.flatMap(value, el => el.products)
    )
}));

结果:

[
   {
      "date":"date",
      "products":[
         {
            "product":"Apple",
            "units":5
         },
         {
            "product":"Pear",
            "units":4
         }
      ]
   }
]