ES6嵌套分组与总和

Ste*_*ven 4 javascript ecmascript-6 lodash

我有这样一个数组:

[{
   id: 1,
   amount: 10,
   date: '21/01/2017'
},{
   id: 1,
   amount: 10,
   date: '21/01/2017'
},{
   id: 1,
   amount: 30,
   date: '22/01/2017'
},{
   id: 2,
   amount: 10,
   date: '21/01/2017'
},]
Run Code Online (Sandbox Code Playgroud)

我希望这输出像:

{
  '21/01/2017': {
    1: {
      amount: 20
    },
    2: {
      amount: 10
    }
  },
  '22/01/2017': {
    1: {
      amount: 30
    }
  }
}
Run Code Online (Sandbox Code Playgroud)

基本上按数据分组,按id嵌套分组,同时汇总相关金额.

到目前为止,我已尝试使用reduce,并查看了lodash函数,但一直没有成功.Reduce使得分组和总和很容易,但我找不到一种优雅的方法来创建第二级.我创建了一个沙箱来演示:

https://codesandbox.io/s/woj9xz6nq5

const dataToConsolidate = [{
  id: 1,
  amount: 10,
  date: '21/01/2017'
}, {
  id: 1,
  amount: 10,
  date: '21/01/2017'
}, {
  id: 1,
  amount: 30,
  date: '22/01/2017'
}, {
  id: 2,
  amount: 10,
  date: '21/01/2017'
},]

export const consolidate = (data) => {
  const result = data.reduce(function (res, obj) {

    (!(obj.date in res)) ?
      res.__array.push(res[obj.date] = obj) :
      res[obj.date].amount += obj.amount;

    return res;
  }, { __array: [] });

  return result;
};

console.log(consolidate(dataToConsolidate))
Run Code Online (Sandbox Code Playgroud)

Nin*_*olz 5

您可以将对象作为哈希表,并使用默认样式添加属性.

var array = [{ id: 1, amount: 10, date: '21/01/2017' }, { id: 1, amount: 10, date: '21/01/2017' }, { id: 1, amount: 30, date: '22/01/2017' }, { id: 2, amount: 10, date: '21/01/2017' }],
    result = {};

array.forEach(function (o) {
    result[o.date] = result[o.date] || {};
    result[o.date][o.id] = result[o.date][o.id] || { amount: 0 };
    result[o.date][o.id].amount += o.amount;
});

console.log(result);
Run Code Online (Sandbox Code Playgroud)
.as-console-wrapper { max-height: 100% !important; top: 0; }
Run Code Online (Sandbox Code Playgroud)