今天写个关于数据聚合吧,就是返回的数据你要根据一个属性做计算。
聚合用groupBy这个函数,它传两个形参一为对象数组,二为匿名函数(该函数功能:返回对象的某个指定属性的属性值并存放在数组中)
groupBy(array, f) {
var _that = this;
_that.groupArr = [];
const groups = {};
array.forEach(function(o) {
const group = JSON.stringify(f(o));
_that.groupArr.push(group);
groups[group] = groups[group] || [];
groups[group].push(o);
});
return groups;
},
我返回的是数组,需要返回key所对应的数组可以
return Object.keys(groups).map(function (group) {
return groups[group];
})
Object.keys(groups)是取出groups对象中的所有key,然后遍历一个个key组成的新数组,返回分好了组的二维数组
- groupBy函数内,先创建一个空对象;
- 然后forEach遍历对象数组,遍历时要执行的函数中只有一个形参o(数组中的每个元素);
- 由于下面函数调用是想用name来分组,因此let group = JSON.stringify( f(o) ),相当于先获取到数组中的name属性对应的属性值并放入数组中,然后再将属性值转换为json字符串;
- groups[group] = groups[group] || [],在js中对象也是关联数组,因此这里相当于做了两件事,一是把group作为groups的key,二是将对应的value初始化,第一次执行为空数组,循环执行时找到相同的name时保持不变;
- groups[group].push( o ),这句相当于把list中每个对象压入数组中作为value;
然后在你需要调用的地方调用
const sorted = this.groupBy(arr, function(item) {
return item.name;
});
我是zhijie