sample = [
{
key1: 'value1',
key2: 'val1',
key3: [{ subkey1: 'a', subkey2: 'b' }]
},
{
key1: 'value2',
key2: 'val2',
key3: [{ subkey1: 'c', subkey2: 'd' }]
},
{
key1: 'value3',
key2: 'val3',
key3: [{ subkey1: 'e', subkey2: 'f' }]
},
{
key1: 'value3',
key2: 'val3',
key3: [{ subkey1: 'g', subkey2: 'h' }]
},
{
key1: 'value3',
key2: 'val3',
key3: [{ subkey1: 'i', subkey2: 'j' }]
},
{ key1: 'value3', key2: 'val3', key3: [{ subkey1: 'k', subkey2: 'l' }] }
];
result = Array.from(
this.sample.reduce(
(m, { key1, key3, key2 }) =>
m.set(key1, [...(m.get(key1) || []), key3, key2]),
new Map()
),
([key1, key3, key2]) => ({ key1, key3, key2 })
);
console.log(result);
I am new to JavaScript and trying to perform a grouping operation on an object-array which looks something as below :
sample = [{key1: "value1", key2: "val1", key3: [{subkey1: "a", subkey2: "b"}]}
{key1: "value2", key2: "val2", key3: [{subkey1: "c", subkey2: "d"}]}
{key1: "value3", key2: "val3", key3: [{subkey1: "e", subkey2: "f"}]}
{key1: "value3", key2: "val3", key3: [{subkey1: "g", subkey2: "h"}]}
{key1: "value3", key2: "val3", key3: [{subkey1: "i", subkey2: "j"}]}
{key1: "value3", key2: "val3", key3: [{subkey1: "k", subkey2: "l"}]]
I tried the following code to group it based on key1 value:
const result = Array.from(sample.reduce((m, {key1, key3, key2}) =>
m.set(key1, [...(m.get(key1) || []), key3, key2]), new Map()), ([key1, key3, key2]) =>
({key1, key3, key2}));
But I get something like this :
[{key1: "value3", key3: [{subkey1: "e", subkey2: "f"},{subkey1: "g",
subkey2: "h"},{subkey1: "i", subkey2: "j"},{subkey1: "k", subkey2:
"l"}], key2: **undefined**},.....etc]
expected:
[{key1: "value3", key3: [{subkey1: "e", subkey2: "f"},{subkey1: "g",
subkey2: "h"},{subkey1: "i", subkey2: "j"},{subkey1: "k", subkey2:
"l"}],, key2: "val3"},.....etc]
key 2 remains undefined here. Can somebody tell me where I am doing wrong or any other ways to get the result as expected.
Thanks,