0

I just started learning JavaScript, and ran into such a problem, I have a nested array, I want to summarize the price value of these arrays and return the existing sum, I wonder which method is applicable for it, which does not hurt the performance, I need one example to understand the way to solve the problem. Thanks in advance

const initialData = [
      {
          title: 'm2212',
          data: [
              {
                  id: 98233181232,
                  variations:[{
                          warranty: '',
                          price: 120,
                          comment: '',
                      }]
  
              },
          ]
      },
      {
          title: 'm2',
          data: [
              {
                  id: 982812,
                  variations:[{
                          warranty: '',
                          price: 92,
                          comment: '',
                      }]
  
              },
               {
                  id: 92182812,
                  variations:[{
                          warranty: '',
                          price: 922,
                          comment: '',
                      }]
  
              },
          ]
      },
 ]
 
 
 
 //what i tried
 let sum = 0
 initialData.forEach((el)=>{
   el.data.forEach((el1)=>{
     sum = sum + el1.variations[0].price
    })
 })

 console.log(sum);

2
  • Write a double loop, loop through initialData first, loop through data array next then through variations array. Keep on adding variations value to a variable. This will give the sum. Commented Feb 9, 2022 at 11:55
  • 1
    Does this answer your question? Better way to sum a property value in an array Commented Feb 9, 2022 at 11:57

3 Answers 3

2

Your data structure looks pretty simple, so I'll just explain in plain english how to accomplish it:

The simple straight forward way is to ignore all the fancy functional things you can do on arrays, and just do this:

Set a sum variable equal to 0. Iterate over every element of initialData. On each element, iterate over every element of data. On each data element, iterate over every element of variations. Add the price property to your sum variable.

Sign up to request clarification or add additional context in comments.

1 Comment

Hi, please incooperate this as a comment.
1

The simplest and performant approach would be something like this code:

  const sum = initialData.reduce((sum, item) => {
    const itemSum = item.data.reduce((dataSum, dataItem) => {
      const itemDataSum = dataItem.variations.reduce((variantsSum, variantItem) => {
        return variantsSum + variantItem.price;
      }, 0);

      return dataSum + itemDataSum;
    }, 0);
    return sum + itemSum;
  }, 0);

  const initialData = [
    {
      title: "m2212",
      data: [
        {
          id: 98233181232,
          variations: [
            {
              warranty: "",
              price: 120,
              comment: ""
            }
          ]
        }
      ]
    },
    {
      title: "m2",
      data: [
        {
          id: 982812,
          variations: [
            {
              warranty: "",
              price: 92,
              comment: ""
            }
          ]
        },
        {
          id: 92182812,
          variations: [
            {
              warranty: "",
              price: 922,
              comment: ""
            }
          ]
        }
      ]
    }
  ];

  const sum = initialData.reduce((sum, item) => {
    const itemSum = item.data.reduce((dataSum, dataItem) => {
      const itemDataSum = dataItem.variations.reduce((variantsSum, variantItem) => {
        return variantsSum + variantItem.price;
      }, 0);

      return dataSum + itemDataSum;
    }, 0);
    return sum + itemSum;
  }, 0);

  console.log(sum);

Comments

1

You could add some checks for having an array or object and if so iterate the values.

This approach does not need to know the structure of the data, it takes breadth-first search for finding the wanted key.

const
    sum = (value, key) => {
        if (!value || typeof value !== 'object') return 0;
        if (Array.isArray(value)) return value.reduce((t, o) => t + sum(o, key), 0);
        if (key in value) return value[key];
        return sum(Object.values(value), key);
    },
    data = [{ title: 'm2212', data: [{ id: 98233181232, variations: [{ warranty: '', price: 120, comment: '' }] }] }, { title: 'm2', data: [{ id: 982812, variations: [{ warranty: '', price: 92, comment: '' }] }, { id: 92182812, variations: [{ warranty: '', price: 922, comment: '' }] }] }];

console.log(sum(data, 'price'));

Comments

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.