2016-06-13 132 views
0

如標題所述,我需要將對象數組推送到分組對象中。我發現這裏的例子,它有云:對象數組中的對象數組在JavaScript中計算總計數

function groupBy(array, col, value) { 
    var r = [], o = {}; 
    array.forEach(function (a) { 
     if (!o[a[col]]) { 
      o[a[col]] = {}; 
      o[a[col]][col] = a[col]; 
      o[a[col]][value] = 0; 
      r.push(o[a[col]]); 

     } 
     o[a[col]][value] += +a[value]; 
    }); 
    return r; 
}; 

var data = [{ Phase: "Phase 1", Step: "Step 1", Task: "Task 1", Value: "5" }, { Phase: "Phase 1", Step: "Step 1", Task: "Task 2", Value: "10" }, { Phase: "Phase 1", Step: "Step 2", Task: "Task 1", Value: "15" }, { Phase: "Phase 1", Step: "Step 2", Task: "Task 2", Value: "20" }, { Phase: "Phase 2", Step: "Step 1", Task: "Task 1", Value: "25" }, { Phase: "Phase 2", Step: "Step 1", Task: "Task 2", Value: "30" }, { Phase: "Phase 2", Step: "Step 2", Task: "Task 1", Value: "35" }, { Phase: "Phase 2", Step: "Step 2", Task: "Task 2", Value: "40" }]; 

document.write('<pre>' + JSON.stringify(groupBy(data, 'Phase', 'Value'), 0, 4) + '</pre>'); 

我的結果是:

[ 
    { 
     "Phase": "Phase 1", 
     "Value": 50 
    }, 
    { 
     "Phase": "Phase 2", 
     "Value": 130 
    } 
] 

我想的是,我的組合對象裏面對象的數組屬性:任務和價值(每任務我想要價值)。

我嘗試這樣做:

function groupBy(array, col, col2, value) { 
    var r = [], o = {}; 
    array.forEach(function (a) { 
     if (!o[a[col]]) { 
      o[a[col]] = {}; 
      o[a[col]][col] = a[col]; 
      o[a[col]][col2] = a[col2]; 
      o[a[col]][value] = 0; 
      r.push(o[a[col]]); 

     } 
     o[a[col]][value] += +a[value]; 
    }); 
    return r; 
}; 

,並添加 「任務」 的參數,但只有我得到的是:

[ 
    { 
     "Phase": "Phase 1", 
     "Task" : "Task 1", 
     "Value": 50 
    }, 
    { 
     "Phase": "Phase 2", 
     "Task" : "Task 1", 
     "Value": 130 
    } 
] 

感謝您的幫助!

回答

1

您正在使用PhaseTask作爲散列表中的密鑰。所以代碼需要像這樣改變

function groupBy(array, col, col2, value) { 
    var r = [], 
    o = {}; 
    array.forEach(function(a) { 
    // key is not 'Phase' only, it should combine 'Phase' and 'Task', others are the same. 
    if (!o[a[col] + a[col2]]) { 
     o[a[col] + a[col2]] = {}; 
     o[a[col] + a[col2]][col] = a[col]; 
     o[a[col] + a[col2]][col2] = a[col2]; 
     o[a[col] + a[col2]][value] = 0; 
     r.push(o[a[col] + a[col2]]); 

    } 
    o[a[col] + a[col2]][value] += +a[value]; 
    }); 
    return r; 
}; 

結帳here

+0

謝謝!這清除了我很多! :) –