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組成的新數組,返回分好了組的二維數組

代碼中,我把分組參數多加了一個,結果顯示也是可以分組成功的。

發佈了19 篇原創文章 · 獲贊 1 · 訪問量 3萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章