JS对象数组根据属性分组方法

 
  1. function test() {

  2. var list = [

  3. {"name": "John", "Average": 15, "High": 10, "DtmStamp": 1358226000000},

  4. {"name": "Jane", "Average": 16, "High": 92, "DtmStamp": 1358226000000},

  5. {"name": "Jane", "Average": 17, "High": 45, "DtmStamp": 1358226000000},

  6. {"name": "John", "Average": 18, "High": 87, "DtmStamp": 1358226000000},

  7. {"name": "Jane", "Average": 15, "High": 10, "DtmStamp": 1358226060000},

  8. {"name": "John", "Average": 16, "High": 87, "DtmStamp": 1358226060000},

  9. {"name": "John", "Average": 17, "High": 45, "DtmStamp": 1358226060000},

  10. {"name": "Jane", "Average": 18, "High": 92, "DtmStamp": 1358226060000}

  11. ];

  12.  
  13. var sorted = this.groupBy(list, function (item) {

  14. return [item.name + item.High];

  15. });

  16. console.log(sorted);

  17. }

  18. test();

  19.  
  20. function groupBy(array, f) {

  21. debugger;

  22. var groups = {};

  23. array.forEach(function (o) {

  24. var group = JSON.stringify(f(o));

  25. groups[group] = groups[group] || [];

  26. groups[group].push(o);

  27. });

  28. return Object.keys(groups).map(function (group) {

  29. return groups[group];

  30. });

  31. }

具体实现思路:

  1. 函数groupBy有两个形参,一为对象数组,二为匿名函数(该函数功能:返回对象的某个指定属性的属性值并存放在数组中);
  2. groupBy函数内,先创建一个空对象;
  3. 然后forEach遍历对象数组,遍历时要执行的函数中只有一个形参o(数组中的每个元素);
  4. 由于下面函数调用是想用name来分组,因此let group = JSON.stringify( f(o) ),相当于先获取到对象数组list中的name属性对应的属性值并放入数组中:["John"],然后再将属性值转换为json字符串:'["John"]';
  5. groups[group] = groups[group] || [],在js中对象也是关联数组,因此这里相当于做了两件事,一是把group作为groups的key,二是将对应的value初始化,第一次执行为空数组,循环执行时找到相同的name时保持不变;
  6. groups[group].push( o ),这句相当于把list中每个对象压入数组中作为value;
  7. 最后,Object.keys(groups)是取出groups对象中的所有key,然后遍历一个个key组成的新数组,返回分好了组的二维数组

代码中,我把分组参数多加了一个,结果显示也是可以分组成功的。

你可能感兴趣的:(js笔记)