简体   繁体   中英

Sum nested array

I have an array within an array of objects and I want to sum the values within the nested array.

[{BenefitType:'401k',
   Beneficiaries: [{Name: 'PersonA', Percentage: 20},
                   {Name: 'PersonB', Percentage: 30},
                   {Name: 'PersonC', Percentage: 50}]
},
 {BenefitType:'IRA',
   Beneficiaries: [{Name: 'PersonA', Percentage: 15},
                   {Name: 'PersonB', Percentage: 45},
                   {Name: 'PersonC', Percentage: 40}]
}];

I would like to sum all the percentages by their Benefit Type so that 401k = 100 and IRA = 100 .

I have the following code, but it gives me a grand total for percentages instead of totals for each benefit type:

var myTotal = 0;

for(var i = 0; i < data.benefit_type.length; i++) {
    for(var j=0; j < data.benefit_type[i].beneficiaries.length; j++) {
        myTotal += parseInt(data.benefit_type[i].beneficiaries[j].percentage); 
        data.benefit_type[i].percent_total = myTotal;

    } 
}

What am I missing to fix this?

You can use .forEach() to iterate through all objects and .reduce() to sum inner arrays:

 let array = [{BenefitType:'401k', Beneficiaries: [{Name: 'PersonA', Percentage: 20}, {Name: 'PersonB', Percentage: 30}, {Name: 'PersonC', Percentage: 50}] }, {BenefitType:'IRA', Beneficiaries: [{Name: 'PersonA', Percentage: 15}, {Name: 'PersonB', Percentage: 45}, {Name: 'PersonC', Percentage: 40}] }]; array.forEach(x => x.TotalPercentage = x.Beneficiaries.reduce((val, cur) => val + cur.Percentage, 0)); console.log(array); 

EDIT:

To fix your code with double for loop you should set your myTotal variable to zero when you leave inner loop:

for(var i = 0; i < data.benefit_type.length; i++) {
    for(var j=0; j < data.benefit_type[i].Beneficiaries.length; j++) {
        myTotal += data.benefit_type[i].Beneficiaries[j].Percentage; 
        data.benefit_type[i].percent_total = myTotal;
    }
    myTotal = 0;
}

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM