js的group By


 js中的;類似group By的方法

const sorted = this.groupBy(rows, function (item) {
return [item.ticket_id];
});
console.log(sorted);
function groupBy(array, f) {
debugger;
const groups = {};
array.forEach(function (o) {
const group = JSON.stringify(f(o));
groups[group] = groups[group] || [];
groups[group].push(o);
});
return Object.keys(groups).map(function (group) {
return groups[group];
});
}

具體實現思路:

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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM