1

I trying to creating an object from an array that contains many arrays. The array element are to be nested keys of object for each other, only if the key has not be created initially. That is, it should not overwrite key and should also maintained key index.

Example is this -


const MainArray = [
                    {
                      key: ['name', 'dog', 'feature', 'hairy'],
                      value1:1 , 
                      value2:2
                     },
                    {
                      key: ['name', 'dog', 'eye', 'brown'],
                      value1:1 , 
                      value2:2
                     }, 
                    {
                      key: ['kind', 'human', 'class', 'man', 'height', 'tall'],
                      value1:'Mike' , 
                      value2:'John'
                     }, 
                     {
                      key: ['kind', 'human', 'class', 'woman', 'hobby'],
                      value1:'Cyling' , 
                      value2:'Tennis'
                     }, 

                ]


const requiredObject = 
                     {

                      name:{
                          dog :{
                            feature:{
                                   hairy :{value1:1, value2:2}
                            },
                            eye:{
                                brown:{value1:1, value2:2}
                             }
                           }
                        },
                        kind:{
                           human:{
                              class:{
                                   man:{
                                      height:{
                                        tall:{value1:'Mike', value2:'John'}
                                      }
                                   },
                                   woman:{
                                       hobby:{value1:'Cyling', value2: 'Tennis'}
                                   } 
                                }
                            }
                         }

                     }

How can I go from MainArray to requireObject

1 Answer 1

1

You can use array.reduce() to build a new object by traversing key arrays using another array.reduce(). Try:

const MainArray = [
    {
      key: ['name', 'dog', 'feature', 'hairy'],
      value1:1 , 
      value2:2
     },
    {
      key: ['name', 'dog', 'eye', 'brown'],
      value1:1 , 
      value2:2
     }, 
    {
      key: ['kind', 'human', 'class', 'man', 'height', 'tall'],
      value1:'Mike' , 
      value2:'John'
     }, 
     {
      key: ['kind', 'human', 'class', 'woman', 'hobby'],
      value1:'Cyling' , 
      value2:'Tennis'
     }
];


const result = MainArray.reduce((acc, cur) => {
    let { key, ...data } = cur;
    let lastIndex = key.length - 1;

    key.reduce((obj, k, index) => {
        obj[k] = obj[k] || (index === lastIndex ? {...data}  : {});
        return obj[k];
    }, acc);

    return acc;
}, {});

console.log(result);

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

Comments

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.