How to convert array of objects to single object which has dynamic key in typescriptDoes JavaScript Guarantee...

What happened to Ghost?

Is it the same airport YUL and YMQ in Canada?

Hang 20lb projector screen on Hardieplank

How to scale a verbatim environment on a minipage?

Airbnb - host wants to reduce rooms, can we get refund?

Can commander tax be proliferated?

What word means "to make something obsolete"?

Why is this a valid proof for the harmonic series?

Any examples of headwear for races with animal ears?

Copy line and insert it in a new position with sed or awk

Accidentally deleted the "/usr/share" folder

Historically, were women trained for obligatory wars? Or did they serve some other military function?

Applying a function to a nested list

I caught several of my students plagiarizing. Could it be my fault as a teacher?

Why is Thanos so tough at the beginning of "Avengers: Endgame"?

Survey Confirmation - Emphasize the question or the answer?

Selecting a secure PIN for building access

When and why did journal article titles become descriptive, rather than creatively allusive?

Entropy as a function of temperature: is temperature well defined?

Can fracking help reduce CO2?

Is Cola "probably the best-known" Latin word in the world? If not, which might it be?

Is thermodynamics only applicable to systems in equilibrium?

Binary Numbers Magic Trick

Transfer over $10k



How to convert array of objects to single object which has dynamic key in typescript


Does JavaScript Guarantee Object Property Order?How do I remove a property from a JavaScript object?How do I check if an array includes an object in JavaScript?How to append something to an array?How to insert an item into an array at a specific index (JavaScript)?Checking if a key exists in a JavaScript object?Sort array of objects by string property valueHow do I empty an array in JavaScript?How to check if an object is an array?How do I remove a particular element from an array in JavaScript?Find object by id in an array of JavaScript objects






.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty{ height:90px;width:728px;box-sizing:border-box;
}







6















This question might be similar to frequently asked one, but this one has some different approach.



In my angular 7 application, I have the following 5 arrays which needs to be converted to the below single object with dynamic key based on the id.



{
"enabled-41": true,
"enabled-42": true,
"enabled-43": true,
"enabled-44": true,
"enabled-45": false,
"abc-41": "some description 1",
"abc-42": "some description 12",
"abc-43": "some description 123",
"abc-44": "some description 1234",
"abc-45": null,
"def-41": "some description 2",
"def-42": "some description 23",
"def-43": "some description 234",
"def-44": "some description 2345",
"def-45": null,
"type-41": "def",
"type-42": "abc",
"type-43": "def",
"type-44": "abc",
"type-45": null,
"weight-41": "25",
"weight-42": "25",
"weight-43": "25",
"weight-44": "25",
"weight-45": null
}





let arr = [
{
"id": 41,
"abc": "some description 1",
"def": "some description 2",
"type": "def",
"Criteria": {
"id": 5,
"question": "follow-up",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 42,
"abc": "some description 12",
"def": "some description 23",
"type": "abc",
"Criteria": {
"id": 1,
"question": "coverage",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 43,
"abc": "some description 123",
"def": "some description 234",
"type": "def",
"Criteria": {
"id": 4,
"question": "Price",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 44,
"abc": "some description 1234",
"def": "some description 2345",
"type": "abc",
"Criteria": {
"id": 3,
"question": "Exchange",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 45,
"Criteria": {
"id": 2,
"definition": "definition conent",
"question": "Random",
"status": true
},
"type": null,
"abc": null,
"def": null,
"weight": 0,
"enabled": false
}
];

let result = arr.reduce(function(obj, item) {
obj[item] = item.value;
return obj;
}, {})

console.log(result);





I have tried using reduce function, but cannot able to get the right way to convert to a single object with the above format based on dynamic key (joining id with hypen).



Can someone help me with this?










share|improve this question

























  • What about the Criteria object? What should happen? Should it be discarded?

    – Jack Bashford
    1 hour ago











  • Yes Criteria object can be discarded and want to get the single object as above

    – UI_Dev
    1 hour ago




















6















This question might be similar to frequently asked one, but this one has some different approach.



In my angular 7 application, I have the following 5 arrays which needs to be converted to the below single object with dynamic key based on the id.



{
"enabled-41": true,
"enabled-42": true,
"enabled-43": true,
"enabled-44": true,
"enabled-45": false,
"abc-41": "some description 1",
"abc-42": "some description 12",
"abc-43": "some description 123",
"abc-44": "some description 1234",
"abc-45": null,
"def-41": "some description 2",
"def-42": "some description 23",
"def-43": "some description 234",
"def-44": "some description 2345",
"def-45": null,
"type-41": "def",
"type-42": "abc",
"type-43": "def",
"type-44": "abc",
"type-45": null,
"weight-41": "25",
"weight-42": "25",
"weight-43": "25",
"weight-44": "25",
"weight-45": null
}





let arr = [
{
"id": 41,
"abc": "some description 1",
"def": "some description 2",
"type": "def",
"Criteria": {
"id": 5,
"question": "follow-up",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 42,
"abc": "some description 12",
"def": "some description 23",
"type": "abc",
"Criteria": {
"id": 1,
"question": "coverage",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 43,
"abc": "some description 123",
"def": "some description 234",
"type": "def",
"Criteria": {
"id": 4,
"question": "Price",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 44,
"abc": "some description 1234",
"def": "some description 2345",
"type": "abc",
"Criteria": {
"id": 3,
"question": "Exchange",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 45,
"Criteria": {
"id": 2,
"definition": "definition conent",
"question": "Random",
"status": true
},
"type": null,
"abc": null,
"def": null,
"weight": 0,
"enabled": false
}
];

let result = arr.reduce(function(obj, item) {
obj[item] = item.value;
return obj;
}, {})

console.log(result);





I have tried using reduce function, but cannot able to get the right way to convert to a single object with the above format based on dynamic key (joining id with hypen).



Can someone help me with this?










share|improve this question

























  • What about the Criteria object? What should happen? Should it be discarded?

    – Jack Bashford
    1 hour ago











  • Yes Criteria object can be discarded and want to get the single object as above

    – UI_Dev
    1 hour ago
















6












6








6


1






This question might be similar to frequently asked one, but this one has some different approach.



In my angular 7 application, I have the following 5 arrays which needs to be converted to the below single object with dynamic key based on the id.



{
"enabled-41": true,
"enabled-42": true,
"enabled-43": true,
"enabled-44": true,
"enabled-45": false,
"abc-41": "some description 1",
"abc-42": "some description 12",
"abc-43": "some description 123",
"abc-44": "some description 1234",
"abc-45": null,
"def-41": "some description 2",
"def-42": "some description 23",
"def-43": "some description 234",
"def-44": "some description 2345",
"def-45": null,
"type-41": "def",
"type-42": "abc",
"type-43": "def",
"type-44": "abc",
"type-45": null,
"weight-41": "25",
"weight-42": "25",
"weight-43": "25",
"weight-44": "25",
"weight-45": null
}





let arr = [
{
"id": 41,
"abc": "some description 1",
"def": "some description 2",
"type": "def",
"Criteria": {
"id": 5,
"question": "follow-up",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 42,
"abc": "some description 12",
"def": "some description 23",
"type": "abc",
"Criteria": {
"id": 1,
"question": "coverage",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 43,
"abc": "some description 123",
"def": "some description 234",
"type": "def",
"Criteria": {
"id": 4,
"question": "Price",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 44,
"abc": "some description 1234",
"def": "some description 2345",
"type": "abc",
"Criteria": {
"id": 3,
"question": "Exchange",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 45,
"Criteria": {
"id": 2,
"definition": "definition conent",
"question": "Random",
"status": true
},
"type": null,
"abc": null,
"def": null,
"weight": 0,
"enabled": false
}
];

let result = arr.reduce(function(obj, item) {
obj[item] = item.value;
return obj;
}, {})

console.log(result);





I have tried using reduce function, but cannot able to get the right way to convert to a single object with the above format based on dynamic key (joining id with hypen).



Can someone help me with this?










share|improve this question
















This question might be similar to frequently asked one, but this one has some different approach.



In my angular 7 application, I have the following 5 arrays which needs to be converted to the below single object with dynamic key based on the id.



{
"enabled-41": true,
"enabled-42": true,
"enabled-43": true,
"enabled-44": true,
"enabled-45": false,
"abc-41": "some description 1",
"abc-42": "some description 12",
"abc-43": "some description 123",
"abc-44": "some description 1234",
"abc-45": null,
"def-41": "some description 2",
"def-42": "some description 23",
"def-43": "some description 234",
"def-44": "some description 2345",
"def-45": null,
"type-41": "def",
"type-42": "abc",
"type-43": "def",
"type-44": "abc",
"type-45": null,
"weight-41": "25",
"weight-42": "25",
"weight-43": "25",
"weight-44": "25",
"weight-45": null
}





let arr = [
{
"id": 41,
"abc": "some description 1",
"def": "some description 2",
"type": "def",
"Criteria": {
"id": 5,
"question": "follow-up",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 42,
"abc": "some description 12",
"def": "some description 23",
"type": "abc",
"Criteria": {
"id": 1,
"question": "coverage",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 43,
"abc": "some description 123",
"def": "some description 234",
"type": "def",
"Criteria": {
"id": 4,
"question": "Price",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 44,
"abc": "some description 1234",
"def": "some description 2345",
"type": "abc",
"Criteria": {
"id": 3,
"question": "Exchange",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 45,
"Criteria": {
"id": 2,
"definition": "definition conent",
"question": "Random",
"status": true
},
"type": null,
"abc": null,
"def": null,
"weight": 0,
"enabled": false
}
];

let result = arr.reduce(function(obj, item) {
obj[item] = item.value;
return obj;
}, {})

console.log(result);





I have tried using reduce function, but cannot able to get the right way to convert to a single object with the above format based on dynamic key (joining id with hypen).



Can someone help me with this?






let arr = [
{
"id": 41,
"abc": "some description 1",
"def": "some description 2",
"type": "def",
"Criteria": {
"id": 5,
"question": "follow-up",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 42,
"abc": "some description 12",
"def": "some description 23",
"type": "abc",
"Criteria": {
"id": 1,
"question": "coverage",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 43,
"abc": "some description 123",
"def": "some description 234",
"type": "def",
"Criteria": {
"id": 4,
"question": "Price",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 44,
"abc": "some description 1234",
"def": "some description 2345",
"type": "abc",
"Criteria": {
"id": 3,
"question": "Exchange",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 45,
"Criteria": {
"id": 2,
"definition": "definition conent",
"question": "Random",
"status": true
},
"type": null,
"abc": null,
"def": null,
"weight": 0,
"enabled": false
}
];

let result = arr.reduce(function(obj, item) {
obj[item] = item.value;
return obj;
}, {})

console.log(result);





let arr = [
{
"id": 41,
"abc": "some description 1",
"def": "some description 2",
"type": "def",
"Criteria": {
"id": 5,
"question": "follow-up",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 42,
"abc": "some description 12",
"def": "some description 23",
"type": "abc",
"Criteria": {
"id": 1,
"question": "coverage",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 43,
"abc": "some description 123",
"def": "some description 234",
"type": "def",
"Criteria": {
"id": 4,
"question": "Price",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 44,
"abc": "some description 1234",
"def": "some description 2345",
"type": "abc",
"Criteria": {
"id": 3,
"question": "Exchange",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 45,
"Criteria": {
"id": 2,
"definition": "definition conent",
"question": "Random",
"status": true
},
"type": null,
"abc": null,
"def": null,
"weight": 0,
"enabled": false
}
];

let result = arr.reduce(function(obj, item) {
obj[item] = item.value;
return obj;
}, {})

console.log(result);






javascript arrays typescript object ecmascript-6






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited 54 mins ago









Jack Bashford

19.2k52050




19.2k52050










asked 1 hour ago









UI_DevUI_Dev

1,31792453




1,31792453













  • What about the Criteria object? What should happen? Should it be discarded?

    – Jack Bashford
    1 hour ago











  • Yes Criteria object can be discarded and want to get the single object as above

    – UI_Dev
    1 hour ago





















  • What about the Criteria object? What should happen? Should it be discarded?

    – Jack Bashford
    1 hour ago











  • Yes Criteria object can be discarded and want to get the single object as above

    – UI_Dev
    1 hour ago



















What about the Criteria object? What should happen? Should it be discarded?

– Jack Bashford
1 hour ago





What about the Criteria object? What should happen? Should it be discarded?

– Jack Bashford
1 hour ago













Yes Criteria object can be discarded and want to get the single object as above

– UI_Dev
1 hour ago







Yes Criteria object can be discarded and want to get the single object as above

– UI_Dev
1 hour ago














4 Answers
4






active

oldest

votes


















4














You code is almost there. But object keys order is not guaranteed. Inside the reduce callback function add the keys in the accumulator and corresponding value.



Use template literals & square notation while creating the object keys






let arr = [{
"id": 41,
"abc": "some description 1",
"def": "some description 2",
"type": "def",
"Criteria": {
"id": 5,
"question": "follow-up",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 42,
"abc": "some description 12",
"def": "some description 23",
"type": "abc",
"Criteria": {
"id": 1,
"question": "coverage",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 43,
"abc": "some description 123",
"def": "some description 234",
"type": "def",
"Criteria": {
"id": 4,
"question": "Price",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 44,
"abc": "some description 1234",
"def": "some description 2345",
"type": "abc",
"Criteria": {
"id": 3,
"question": "Exchange",
"definition": "definition content",
"status": true
},
"weight": 25,
"enabled": true
},
{
"id": 45,
"Criteria": {
"id": 2,
"definition": "definition conent",
"question": "Random",
"status": true
},
"type": null,
"abc": null,
"def": null,
"weight": 0,
"enabled": false
}
];

let result = arr.reduce(function(obj, item) {
obj[`enabled-${item.id}`] = item.enabled;
obj[`abc-${item.id}`] = item.abc;
obj[`def-${item.id}`] = item.def;
obj[`type-${item.id}`] = item.type;
obj[`weight-${item.id}`] = item.weight;
return obj;
}, {});
console.log(result)








share|improve this answer
























  • Thanks, is there any possibility with the object key order?

    – UI_Dev
    52 mins ago











  • @UI_Dev hopefully this link stackoverflow.com/questions/5525795/… will help you

    – brk
    50 mins ago











  • Thank you... @brk

    – UI_Dev
    41 mins ago











  • why downvote? Please clarify

    – brk
    6 mins ago



















4














You can use reduce with Object.keys, and place all keys you wish to exclude in an array and check against that:






let arr = [{"id":41,"abc":"some description 1","def":"some description 2","type":"def","Criteria":{"id":5,"question":"follow-up","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":42,"abc":"some description 12","def":"some description 23","type":"abc","Criteria":{"id":1,"question":"coverage","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":43,"abc":"some description 123","def":"some description 234","type":"def","Criteria":{"id":4,"question":"Price","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":44,"abc":"some description 1234","def":"some description 2345","type":"abc","Criteria":{"id":3,"question":"Exchange","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":45,"Criteria":{"id":2,"definition":"definition conent","question":"Random","status":true},"type":null,"abc":null,"def":null,"weight":0,"enabled":false}];

let exclude = ["id", "Criteria"];

let result = arr.reduce((acc, curr) => {
let id = curr.id;
Object.entries(curr).forEach(([k, v]) => {
if (!exclude.includes(k)) acc[`${k}-${id}`] = v;
});
return acc;
}, {});

console.log(result);








share|improve this answer
























  • Thanks Jack...!

    – UI_Dev
    40 mins ago



















2














Assuming you want to exclude all the properties whose value is an object maybe you can go with this generic idea that uses Object.entries() to traverse the inner objects and some destructuring features.






let arr=[{"id":41,"abc":"some description 1","def":"some description 2","type":"def","Criteria":{"id":5,"question":"follow-up","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":42,"abc":"some description 12","def":"some description 23","type":"abc","Criteria":{"id":1,"question":"coverage","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":43,"abc":"some description 123","def":"some description 234","type":"def","Criteria":{"id":4,"question":"Price","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":44,"abc":"some description 1234","def":"some description 2345","type":"abc","Criteria":{"id":3,"question":"Exchange","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":45,"Criteria":{"id":2,"definition":"definition conent","question":"Random","status":true},"type":null,"abc":null,"def":null,"weight":0,"enabled":false}];

let result = arr.reduce((obj, {id, ...rest}) =>
{
Object.entries(rest).forEach(([k, v]) =>
{
if (Object(v) !== v) obj[`${k}-${id}`] = v;
});

return obj;
}, {});

console.log(result);

.as-console {background-color:black !important; color:lime;}
.as-console-wrapper {max-height:100% !important; top:0;}








share|improve this answer
























  • Thanks Shidersz..!

    – UI_Dev
    40 mins ago



















1














Oh, man... I just got beat. Here's my solution.



let arr= [] // hold the final object array
let keys = [] // temp item to hold the value of each key

// iterate over each key
Object.keys(input).forEach((key) => {
let pair = key.split('-') // split the key into the real key and the index

// if the index isn't in the array, push it there (this keeps the same order)
if (keys.indexOf(pair[1])===-1) {
keys.push(pair[1])
}

// use object.assign to add the keys to the existing object in the right place in the array.
arr[keys.indexOf(pair[1])] = Object.assign({}, arr[keys.indexOf(pair[1])], {[pair[0]]: input[key]}, { id: pair[1] })

})





share|improve this answer
























    Your Answer






    StackExchange.ifUsing("editor", function () {
    StackExchange.using("externalEditor", function () {
    StackExchange.using("snippets", function () {
    StackExchange.snippets.init();
    });
    });
    }, "code-snippets");

    StackExchange.ready(function() {
    var channelOptions = {
    tags: "".split(" "),
    id: "1"
    };
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function() {
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled) {
    StackExchange.using("snippets", function() {
    createEditor();
    });
    }
    else {
    createEditor();
    }
    });

    function createEditor() {
    StackExchange.prepareEditor({
    heartbeatType: 'answer',
    autoActivateHeartbeat: false,
    convertImagesToLinks: true,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: 10,
    bindNavPrevention: true,
    postfix: "",
    imageUploader: {
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    },
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    });


    }
    });














    draft saved

    draft discarded


















    StackExchange.ready(
    function () {
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55914053%2fhow-to-convert-array-of-objects-to-single-object-which-has-dynamic-key-in-typesc%23new-answer', 'question_page');
    }
    );

    Post as a guest















    Required, but never shown

























    4 Answers
    4






    active

    oldest

    votes








    4 Answers
    4






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    4














    You code is almost there. But object keys order is not guaranteed. Inside the reduce callback function add the keys in the accumulator and corresponding value.



    Use template literals & square notation while creating the object keys






    let arr = [{
    "id": 41,
    "abc": "some description 1",
    "def": "some description 2",
    "type": "def",
    "Criteria": {
    "id": 5,
    "question": "follow-up",
    "definition": "definition content",
    "status": true
    },
    "weight": 25,
    "enabled": true
    },
    {
    "id": 42,
    "abc": "some description 12",
    "def": "some description 23",
    "type": "abc",
    "Criteria": {
    "id": 1,
    "question": "coverage",
    "definition": "definition content",
    "status": true
    },
    "weight": 25,
    "enabled": true
    },
    {
    "id": 43,
    "abc": "some description 123",
    "def": "some description 234",
    "type": "def",
    "Criteria": {
    "id": 4,
    "question": "Price",
    "definition": "definition content",
    "status": true
    },
    "weight": 25,
    "enabled": true
    },
    {
    "id": 44,
    "abc": "some description 1234",
    "def": "some description 2345",
    "type": "abc",
    "Criteria": {
    "id": 3,
    "question": "Exchange",
    "definition": "definition content",
    "status": true
    },
    "weight": 25,
    "enabled": true
    },
    {
    "id": 45,
    "Criteria": {
    "id": 2,
    "definition": "definition conent",
    "question": "Random",
    "status": true
    },
    "type": null,
    "abc": null,
    "def": null,
    "weight": 0,
    "enabled": false
    }
    ];

    let result = arr.reduce(function(obj, item) {
    obj[`enabled-${item.id}`] = item.enabled;
    obj[`abc-${item.id}`] = item.abc;
    obj[`def-${item.id}`] = item.def;
    obj[`type-${item.id}`] = item.type;
    obj[`weight-${item.id}`] = item.weight;
    return obj;
    }, {});
    console.log(result)








    share|improve this answer
























    • Thanks, is there any possibility with the object key order?

      – UI_Dev
      52 mins ago











    • @UI_Dev hopefully this link stackoverflow.com/questions/5525795/… will help you

      – brk
      50 mins ago











    • Thank you... @brk

      – UI_Dev
      41 mins ago











    • why downvote? Please clarify

      – brk
      6 mins ago
















    4














    You code is almost there. But object keys order is not guaranteed. Inside the reduce callback function add the keys in the accumulator and corresponding value.



    Use template literals & square notation while creating the object keys






    let arr = [{
    "id": 41,
    "abc": "some description 1",
    "def": "some description 2",
    "type": "def",
    "Criteria": {
    "id": 5,
    "question": "follow-up",
    "definition": "definition content",
    "status": true
    },
    "weight": 25,
    "enabled": true
    },
    {
    "id": 42,
    "abc": "some description 12",
    "def": "some description 23",
    "type": "abc",
    "Criteria": {
    "id": 1,
    "question": "coverage",
    "definition": "definition content",
    "status": true
    },
    "weight": 25,
    "enabled": true
    },
    {
    "id": 43,
    "abc": "some description 123",
    "def": "some description 234",
    "type": "def",
    "Criteria": {
    "id": 4,
    "question": "Price",
    "definition": "definition content",
    "status": true
    },
    "weight": 25,
    "enabled": true
    },
    {
    "id": 44,
    "abc": "some description 1234",
    "def": "some description 2345",
    "type": "abc",
    "Criteria": {
    "id": 3,
    "question": "Exchange",
    "definition": "definition content",
    "status": true
    },
    "weight": 25,
    "enabled": true
    },
    {
    "id": 45,
    "Criteria": {
    "id": 2,
    "definition": "definition conent",
    "question": "Random",
    "status": true
    },
    "type": null,
    "abc": null,
    "def": null,
    "weight": 0,
    "enabled": false
    }
    ];

    let result = arr.reduce(function(obj, item) {
    obj[`enabled-${item.id}`] = item.enabled;
    obj[`abc-${item.id}`] = item.abc;
    obj[`def-${item.id}`] = item.def;
    obj[`type-${item.id}`] = item.type;
    obj[`weight-${item.id}`] = item.weight;
    return obj;
    }, {});
    console.log(result)








    share|improve this answer
























    • Thanks, is there any possibility with the object key order?

      – UI_Dev
      52 mins ago











    • @UI_Dev hopefully this link stackoverflow.com/questions/5525795/… will help you

      – brk
      50 mins ago











    • Thank you... @brk

      – UI_Dev
      41 mins ago











    • why downvote? Please clarify

      – brk
      6 mins ago














    4












    4








    4







    You code is almost there. But object keys order is not guaranteed. Inside the reduce callback function add the keys in the accumulator and corresponding value.



    Use template literals & square notation while creating the object keys






    let arr = [{
    "id": 41,
    "abc": "some description 1",
    "def": "some description 2",
    "type": "def",
    "Criteria": {
    "id": 5,
    "question": "follow-up",
    "definition": "definition content",
    "status": true
    },
    "weight": 25,
    "enabled": true
    },
    {
    "id": 42,
    "abc": "some description 12",
    "def": "some description 23",
    "type": "abc",
    "Criteria": {
    "id": 1,
    "question": "coverage",
    "definition": "definition content",
    "status": true
    },
    "weight": 25,
    "enabled": true
    },
    {
    "id": 43,
    "abc": "some description 123",
    "def": "some description 234",
    "type": "def",
    "Criteria": {
    "id": 4,
    "question": "Price",
    "definition": "definition content",
    "status": true
    },
    "weight": 25,
    "enabled": true
    },
    {
    "id": 44,
    "abc": "some description 1234",
    "def": "some description 2345",
    "type": "abc",
    "Criteria": {
    "id": 3,
    "question": "Exchange",
    "definition": "definition content",
    "status": true
    },
    "weight": 25,
    "enabled": true
    },
    {
    "id": 45,
    "Criteria": {
    "id": 2,
    "definition": "definition conent",
    "question": "Random",
    "status": true
    },
    "type": null,
    "abc": null,
    "def": null,
    "weight": 0,
    "enabled": false
    }
    ];

    let result = arr.reduce(function(obj, item) {
    obj[`enabled-${item.id}`] = item.enabled;
    obj[`abc-${item.id}`] = item.abc;
    obj[`def-${item.id}`] = item.def;
    obj[`type-${item.id}`] = item.type;
    obj[`weight-${item.id}`] = item.weight;
    return obj;
    }, {});
    console.log(result)








    share|improve this answer













    You code is almost there. But object keys order is not guaranteed. Inside the reduce callback function add the keys in the accumulator and corresponding value.



    Use template literals & square notation while creating the object keys






    let arr = [{
    "id": 41,
    "abc": "some description 1",
    "def": "some description 2",
    "type": "def",
    "Criteria": {
    "id": 5,
    "question": "follow-up",
    "definition": "definition content",
    "status": true
    },
    "weight": 25,
    "enabled": true
    },
    {
    "id": 42,
    "abc": "some description 12",
    "def": "some description 23",
    "type": "abc",
    "Criteria": {
    "id": 1,
    "question": "coverage",
    "definition": "definition content",
    "status": true
    },
    "weight": 25,
    "enabled": true
    },
    {
    "id": 43,
    "abc": "some description 123",
    "def": "some description 234",
    "type": "def",
    "Criteria": {
    "id": 4,
    "question": "Price",
    "definition": "definition content",
    "status": true
    },
    "weight": 25,
    "enabled": true
    },
    {
    "id": 44,
    "abc": "some description 1234",
    "def": "some description 2345",
    "type": "abc",
    "Criteria": {
    "id": 3,
    "question": "Exchange",
    "definition": "definition content",
    "status": true
    },
    "weight": 25,
    "enabled": true
    },
    {
    "id": 45,
    "Criteria": {
    "id": 2,
    "definition": "definition conent",
    "question": "Random",
    "status": true
    },
    "type": null,
    "abc": null,
    "def": null,
    "weight": 0,
    "enabled": false
    }
    ];

    let result = arr.reduce(function(obj, item) {
    obj[`enabled-${item.id}`] = item.enabled;
    obj[`abc-${item.id}`] = item.abc;
    obj[`def-${item.id}`] = item.def;
    obj[`type-${item.id}`] = item.type;
    obj[`weight-${item.id}`] = item.weight;
    return obj;
    }, {});
    console.log(result)








    let arr = [{
    "id": 41,
    "abc": "some description 1",
    "def": "some description 2",
    "type": "def",
    "Criteria": {
    "id": 5,
    "question": "follow-up",
    "definition": "definition content",
    "status": true
    },
    "weight": 25,
    "enabled": true
    },
    {
    "id": 42,
    "abc": "some description 12",
    "def": "some description 23",
    "type": "abc",
    "Criteria": {
    "id": 1,
    "question": "coverage",
    "definition": "definition content",
    "status": true
    },
    "weight": 25,
    "enabled": true
    },
    {
    "id": 43,
    "abc": "some description 123",
    "def": "some description 234",
    "type": "def",
    "Criteria": {
    "id": 4,
    "question": "Price",
    "definition": "definition content",
    "status": true
    },
    "weight": 25,
    "enabled": true
    },
    {
    "id": 44,
    "abc": "some description 1234",
    "def": "some description 2345",
    "type": "abc",
    "Criteria": {
    "id": 3,
    "question": "Exchange",
    "definition": "definition content",
    "status": true
    },
    "weight": 25,
    "enabled": true
    },
    {
    "id": 45,
    "Criteria": {
    "id": 2,
    "definition": "definition conent",
    "question": "Random",
    "status": true
    },
    "type": null,
    "abc": null,
    "def": null,
    "weight": 0,
    "enabled": false
    }
    ];

    let result = arr.reduce(function(obj, item) {
    obj[`enabled-${item.id}`] = item.enabled;
    obj[`abc-${item.id}`] = item.abc;
    obj[`def-${item.id}`] = item.def;
    obj[`type-${item.id}`] = item.type;
    obj[`weight-${item.id}`] = item.weight;
    return obj;
    }, {});
    console.log(result)





    let arr = [{
    "id": 41,
    "abc": "some description 1",
    "def": "some description 2",
    "type": "def",
    "Criteria": {
    "id": 5,
    "question": "follow-up",
    "definition": "definition content",
    "status": true
    },
    "weight": 25,
    "enabled": true
    },
    {
    "id": 42,
    "abc": "some description 12",
    "def": "some description 23",
    "type": "abc",
    "Criteria": {
    "id": 1,
    "question": "coverage",
    "definition": "definition content",
    "status": true
    },
    "weight": 25,
    "enabled": true
    },
    {
    "id": 43,
    "abc": "some description 123",
    "def": "some description 234",
    "type": "def",
    "Criteria": {
    "id": 4,
    "question": "Price",
    "definition": "definition content",
    "status": true
    },
    "weight": 25,
    "enabled": true
    },
    {
    "id": 44,
    "abc": "some description 1234",
    "def": "some description 2345",
    "type": "abc",
    "Criteria": {
    "id": 3,
    "question": "Exchange",
    "definition": "definition content",
    "status": true
    },
    "weight": 25,
    "enabled": true
    },
    {
    "id": 45,
    "Criteria": {
    "id": 2,
    "definition": "definition conent",
    "question": "Random",
    "status": true
    },
    "type": null,
    "abc": null,
    "def": null,
    "weight": 0,
    "enabled": false
    }
    ];

    let result = arr.reduce(function(obj, item) {
    obj[`enabled-${item.id}`] = item.enabled;
    obj[`abc-${item.id}`] = item.abc;
    obj[`def-${item.id}`] = item.def;
    obj[`type-${item.id}`] = item.type;
    obj[`weight-${item.id}`] = item.weight;
    return obj;
    }, {});
    console.log(result)






    share|improve this answer












    share|improve this answer



    share|improve this answer










    answered 1 hour ago









    brkbrk

    30.8k32446




    30.8k32446













    • Thanks, is there any possibility with the object key order?

      – UI_Dev
      52 mins ago











    • @UI_Dev hopefully this link stackoverflow.com/questions/5525795/… will help you

      – brk
      50 mins ago











    • Thank you... @brk

      – UI_Dev
      41 mins ago











    • why downvote? Please clarify

      – brk
      6 mins ago



















    • Thanks, is there any possibility with the object key order?

      – UI_Dev
      52 mins ago











    • @UI_Dev hopefully this link stackoverflow.com/questions/5525795/… will help you

      – brk
      50 mins ago











    • Thank you... @brk

      – UI_Dev
      41 mins ago











    • why downvote? Please clarify

      – brk
      6 mins ago

















    Thanks, is there any possibility with the object key order?

    – UI_Dev
    52 mins ago





    Thanks, is there any possibility with the object key order?

    – UI_Dev
    52 mins ago













    @UI_Dev hopefully this link stackoverflow.com/questions/5525795/… will help you

    – brk
    50 mins ago





    @UI_Dev hopefully this link stackoverflow.com/questions/5525795/… will help you

    – brk
    50 mins ago













    Thank you... @brk

    – UI_Dev
    41 mins ago





    Thank you... @brk

    – UI_Dev
    41 mins ago













    why downvote? Please clarify

    – brk
    6 mins ago





    why downvote? Please clarify

    – brk
    6 mins ago













    4














    You can use reduce with Object.keys, and place all keys you wish to exclude in an array and check against that:






    let arr = [{"id":41,"abc":"some description 1","def":"some description 2","type":"def","Criteria":{"id":5,"question":"follow-up","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":42,"abc":"some description 12","def":"some description 23","type":"abc","Criteria":{"id":1,"question":"coverage","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":43,"abc":"some description 123","def":"some description 234","type":"def","Criteria":{"id":4,"question":"Price","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":44,"abc":"some description 1234","def":"some description 2345","type":"abc","Criteria":{"id":3,"question":"Exchange","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":45,"Criteria":{"id":2,"definition":"definition conent","question":"Random","status":true},"type":null,"abc":null,"def":null,"weight":0,"enabled":false}];

    let exclude = ["id", "Criteria"];

    let result = arr.reduce((acc, curr) => {
    let id = curr.id;
    Object.entries(curr).forEach(([k, v]) => {
    if (!exclude.includes(k)) acc[`${k}-${id}`] = v;
    });
    return acc;
    }, {});

    console.log(result);








    share|improve this answer
























    • Thanks Jack...!

      – UI_Dev
      40 mins ago
















    4














    You can use reduce with Object.keys, and place all keys you wish to exclude in an array and check against that:






    let arr = [{"id":41,"abc":"some description 1","def":"some description 2","type":"def","Criteria":{"id":5,"question":"follow-up","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":42,"abc":"some description 12","def":"some description 23","type":"abc","Criteria":{"id":1,"question":"coverage","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":43,"abc":"some description 123","def":"some description 234","type":"def","Criteria":{"id":4,"question":"Price","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":44,"abc":"some description 1234","def":"some description 2345","type":"abc","Criteria":{"id":3,"question":"Exchange","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":45,"Criteria":{"id":2,"definition":"definition conent","question":"Random","status":true},"type":null,"abc":null,"def":null,"weight":0,"enabled":false}];

    let exclude = ["id", "Criteria"];

    let result = arr.reduce((acc, curr) => {
    let id = curr.id;
    Object.entries(curr).forEach(([k, v]) => {
    if (!exclude.includes(k)) acc[`${k}-${id}`] = v;
    });
    return acc;
    }, {});

    console.log(result);








    share|improve this answer
























    • Thanks Jack...!

      – UI_Dev
      40 mins ago














    4












    4








    4







    You can use reduce with Object.keys, and place all keys you wish to exclude in an array and check against that:






    let arr = [{"id":41,"abc":"some description 1","def":"some description 2","type":"def","Criteria":{"id":5,"question":"follow-up","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":42,"abc":"some description 12","def":"some description 23","type":"abc","Criteria":{"id":1,"question":"coverage","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":43,"abc":"some description 123","def":"some description 234","type":"def","Criteria":{"id":4,"question":"Price","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":44,"abc":"some description 1234","def":"some description 2345","type":"abc","Criteria":{"id":3,"question":"Exchange","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":45,"Criteria":{"id":2,"definition":"definition conent","question":"Random","status":true},"type":null,"abc":null,"def":null,"weight":0,"enabled":false}];

    let exclude = ["id", "Criteria"];

    let result = arr.reduce((acc, curr) => {
    let id = curr.id;
    Object.entries(curr).forEach(([k, v]) => {
    if (!exclude.includes(k)) acc[`${k}-${id}`] = v;
    });
    return acc;
    }, {});

    console.log(result);








    share|improve this answer













    You can use reduce with Object.keys, and place all keys you wish to exclude in an array and check against that:






    let arr = [{"id":41,"abc":"some description 1","def":"some description 2","type":"def","Criteria":{"id":5,"question":"follow-up","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":42,"abc":"some description 12","def":"some description 23","type":"abc","Criteria":{"id":1,"question":"coverage","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":43,"abc":"some description 123","def":"some description 234","type":"def","Criteria":{"id":4,"question":"Price","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":44,"abc":"some description 1234","def":"some description 2345","type":"abc","Criteria":{"id":3,"question":"Exchange","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":45,"Criteria":{"id":2,"definition":"definition conent","question":"Random","status":true},"type":null,"abc":null,"def":null,"weight":0,"enabled":false}];

    let exclude = ["id", "Criteria"];

    let result = arr.reduce((acc, curr) => {
    let id = curr.id;
    Object.entries(curr).forEach(([k, v]) => {
    if (!exclude.includes(k)) acc[`${k}-${id}`] = v;
    });
    return acc;
    }, {});

    console.log(result);








    let arr = [{"id":41,"abc":"some description 1","def":"some description 2","type":"def","Criteria":{"id":5,"question":"follow-up","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":42,"abc":"some description 12","def":"some description 23","type":"abc","Criteria":{"id":1,"question":"coverage","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":43,"abc":"some description 123","def":"some description 234","type":"def","Criteria":{"id":4,"question":"Price","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":44,"abc":"some description 1234","def":"some description 2345","type":"abc","Criteria":{"id":3,"question":"Exchange","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":45,"Criteria":{"id":2,"definition":"definition conent","question":"Random","status":true},"type":null,"abc":null,"def":null,"weight":0,"enabled":false}];

    let exclude = ["id", "Criteria"];

    let result = arr.reduce((acc, curr) => {
    let id = curr.id;
    Object.entries(curr).forEach(([k, v]) => {
    if (!exclude.includes(k)) acc[`${k}-${id}`] = v;
    });
    return acc;
    }, {});

    console.log(result);





    let arr = [{"id":41,"abc":"some description 1","def":"some description 2","type":"def","Criteria":{"id":5,"question":"follow-up","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":42,"abc":"some description 12","def":"some description 23","type":"abc","Criteria":{"id":1,"question":"coverage","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":43,"abc":"some description 123","def":"some description 234","type":"def","Criteria":{"id":4,"question":"Price","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":44,"abc":"some description 1234","def":"some description 2345","type":"abc","Criteria":{"id":3,"question":"Exchange","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":45,"Criteria":{"id":2,"definition":"definition conent","question":"Random","status":true},"type":null,"abc":null,"def":null,"weight":0,"enabled":false}];

    let exclude = ["id", "Criteria"];

    let result = arr.reduce((acc, curr) => {
    let id = curr.id;
    Object.entries(curr).forEach(([k, v]) => {
    if (!exclude.includes(k)) acc[`${k}-${id}`] = v;
    });
    return acc;
    }, {});

    console.log(result);






    share|improve this answer












    share|improve this answer



    share|improve this answer










    answered 55 mins ago









    Jack BashfordJack Bashford

    19.2k52050




    19.2k52050













    • Thanks Jack...!

      – UI_Dev
      40 mins ago



















    • Thanks Jack...!

      – UI_Dev
      40 mins ago

















    Thanks Jack...!

    – UI_Dev
    40 mins ago





    Thanks Jack...!

    – UI_Dev
    40 mins ago











    2














    Assuming you want to exclude all the properties whose value is an object maybe you can go with this generic idea that uses Object.entries() to traverse the inner objects and some destructuring features.






    let arr=[{"id":41,"abc":"some description 1","def":"some description 2","type":"def","Criteria":{"id":5,"question":"follow-up","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":42,"abc":"some description 12","def":"some description 23","type":"abc","Criteria":{"id":1,"question":"coverage","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":43,"abc":"some description 123","def":"some description 234","type":"def","Criteria":{"id":4,"question":"Price","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":44,"abc":"some description 1234","def":"some description 2345","type":"abc","Criteria":{"id":3,"question":"Exchange","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":45,"Criteria":{"id":2,"definition":"definition conent","question":"Random","status":true},"type":null,"abc":null,"def":null,"weight":0,"enabled":false}];

    let result = arr.reduce((obj, {id, ...rest}) =>
    {
    Object.entries(rest).forEach(([k, v]) =>
    {
    if (Object(v) !== v) obj[`${k}-${id}`] = v;
    });

    return obj;
    }, {});

    console.log(result);

    .as-console {background-color:black !important; color:lime;}
    .as-console-wrapper {max-height:100% !important; top:0;}








    share|improve this answer
























    • Thanks Shidersz..!

      – UI_Dev
      40 mins ago
















    2














    Assuming you want to exclude all the properties whose value is an object maybe you can go with this generic idea that uses Object.entries() to traverse the inner objects and some destructuring features.






    let arr=[{"id":41,"abc":"some description 1","def":"some description 2","type":"def","Criteria":{"id":5,"question":"follow-up","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":42,"abc":"some description 12","def":"some description 23","type":"abc","Criteria":{"id":1,"question":"coverage","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":43,"abc":"some description 123","def":"some description 234","type":"def","Criteria":{"id":4,"question":"Price","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":44,"abc":"some description 1234","def":"some description 2345","type":"abc","Criteria":{"id":3,"question":"Exchange","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":45,"Criteria":{"id":2,"definition":"definition conent","question":"Random","status":true},"type":null,"abc":null,"def":null,"weight":0,"enabled":false}];

    let result = arr.reduce((obj, {id, ...rest}) =>
    {
    Object.entries(rest).forEach(([k, v]) =>
    {
    if (Object(v) !== v) obj[`${k}-${id}`] = v;
    });

    return obj;
    }, {});

    console.log(result);

    .as-console {background-color:black !important; color:lime;}
    .as-console-wrapper {max-height:100% !important; top:0;}








    share|improve this answer
























    • Thanks Shidersz..!

      – UI_Dev
      40 mins ago














    2












    2








    2







    Assuming you want to exclude all the properties whose value is an object maybe you can go with this generic idea that uses Object.entries() to traverse the inner objects and some destructuring features.






    let arr=[{"id":41,"abc":"some description 1","def":"some description 2","type":"def","Criteria":{"id":5,"question":"follow-up","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":42,"abc":"some description 12","def":"some description 23","type":"abc","Criteria":{"id":1,"question":"coverage","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":43,"abc":"some description 123","def":"some description 234","type":"def","Criteria":{"id":4,"question":"Price","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":44,"abc":"some description 1234","def":"some description 2345","type":"abc","Criteria":{"id":3,"question":"Exchange","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":45,"Criteria":{"id":2,"definition":"definition conent","question":"Random","status":true},"type":null,"abc":null,"def":null,"weight":0,"enabled":false}];

    let result = arr.reduce((obj, {id, ...rest}) =>
    {
    Object.entries(rest).forEach(([k, v]) =>
    {
    if (Object(v) !== v) obj[`${k}-${id}`] = v;
    });

    return obj;
    }, {});

    console.log(result);

    .as-console {background-color:black !important; color:lime;}
    .as-console-wrapper {max-height:100% !important; top:0;}








    share|improve this answer













    Assuming you want to exclude all the properties whose value is an object maybe you can go with this generic idea that uses Object.entries() to traverse the inner objects and some destructuring features.






    let arr=[{"id":41,"abc":"some description 1","def":"some description 2","type":"def","Criteria":{"id":5,"question":"follow-up","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":42,"abc":"some description 12","def":"some description 23","type":"abc","Criteria":{"id":1,"question":"coverage","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":43,"abc":"some description 123","def":"some description 234","type":"def","Criteria":{"id":4,"question":"Price","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":44,"abc":"some description 1234","def":"some description 2345","type":"abc","Criteria":{"id":3,"question":"Exchange","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":45,"Criteria":{"id":2,"definition":"definition conent","question":"Random","status":true},"type":null,"abc":null,"def":null,"weight":0,"enabled":false}];

    let result = arr.reduce((obj, {id, ...rest}) =>
    {
    Object.entries(rest).forEach(([k, v]) =>
    {
    if (Object(v) !== v) obj[`${k}-${id}`] = v;
    });

    return obj;
    }, {});

    console.log(result);

    .as-console {background-color:black !important; color:lime;}
    .as-console-wrapper {max-height:100% !important; top:0;}








    let arr=[{"id":41,"abc":"some description 1","def":"some description 2","type":"def","Criteria":{"id":5,"question":"follow-up","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":42,"abc":"some description 12","def":"some description 23","type":"abc","Criteria":{"id":1,"question":"coverage","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":43,"abc":"some description 123","def":"some description 234","type":"def","Criteria":{"id":4,"question":"Price","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":44,"abc":"some description 1234","def":"some description 2345","type":"abc","Criteria":{"id":3,"question":"Exchange","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":45,"Criteria":{"id":2,"definition":"definition conent","question":"Random","status":true},"type":null,"abc":null,"def":null,"weight":0,"enabled":false}];

    let result = arr.reduce((obj, {id, ...rest}) =>
    {
    Object.entries(rest).forEach(([k, v]) =>
    {
    if (Object(v) !== v) obj[`${k}-${id}`] = v;
    });

    return obj;
    }, {});

    console.log(result);

    .as-console {background-color:black !important; color:lime;}
    .as-console-wrapper {max-height:100% !important; top:0;}





    let arr=[{"id":41,"abc":"some description 1","def":"some description 2","type":"def","Criteria":{"id":5,"question":"follow-up","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":42,"abc":"some description 12","def":"some description 23","type":"abc","Criteria":{"id":1,"question":"coverage","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":43,"abc":"some description 123","def":"some description 234","type":"def","Criteria":{"id":4,"question":"Price","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":44,"abc":"some description 1234","def":"some description 2345","type":"abc","Criteria":{"id":3,"question":"Exchange","definition":"definition content","status":true},"weight":25,"enabled":true},{"id":45,"Criteria":{"id":2,"definition":"definition conent","question":"Random","status":true},"type":null,"abc":null,"def":null,"weight":0,"enabled":false}];

    let result = arr.reduce((obj, {id, ...rest}) =>
    {
    Object.entries(rest).forEach(([k, v]) =>
    {
    if (Object(v) !== v) obj[`${k}-${id}`] = v;
    });

    return obj;
    }, {});

    console.log(result);

    .as-console {background-color:black !important; color:lime;}
    .as-console-wrapper {max-height:100% !important; top:0;}






    share|improve this answer












    share|improve this answer



    share|improve this answer










    answered 51 mins ago









    ShiderszShidersz

    11.2k2933




    11.2k2933













    • Thanks Shidersz..!

      – UI_Dev
      40 mins ago



















    • Thanks Shidersz..!

      – UI_Dev
      40 mins ago

















    Thanks Shidersz..!

    – UI_Dev
    40 mins ago





    Thanks Shidersz..!

    – UI_Dev
    40 mins ago











    1














    Oh, man... I just got beat. Here's my solution.



    let arr= [] // hold the final object array
    let keys = [] // temp item to hold the value of each key

    // iterate over each key
    Object.keys(input).forEach((key) => {
    let pair = key.split('-') // split the key into the real key and the index

    // if the index isn't in the array, push it there (this keeps the same order)
    if (keys.indexOf(pair[1])===-1) {
    keys.push(pair[1])
    }

    // use object.assign to add the keys to the existing object in the right place in the array.
    arr[keys.indexOf(pair[1])] = Object.assign({}, arr[keys.indexOf(pair[1])], {[pair[0]]: input[key]}, { id: pair[1] })

    })





    share|improve this answer




























      1














      Oh, man... I just got beat. Here's my solution.



      let arr= [] // hold the final object array
      let keys = [] // temp item to hold the value of each key

      // iterate over each key
      Object.keys(input).forEach((key) => {
      let pair = key.split('-') // split the key into the real key and the index

      // if the index isn't in the array, push it there (this keeps the same order)
      if (keys.indexOf(pair[1])===-1) {
      keys.push(pair[1])
      }

      // use object.assign to add the keys to the existing object in the right place in the array.
      arr[keys.indexOf(pair[1])] = Object.assign({}, arr[keys.indexOf(pair[1])], {[pair[0]]: input[key]}, { id: pair[1] })

      })





      share|improve this answer


























        1












        1








        1







        Oh, man... I just got beat. Here's my solution.



        let arr= [] // hold the final object array
        let keys = [] // temp item to hold the value of each key

        // iterate over each key
        Object.keys(input).forEach((key) => {
        let pair = key.split('-') // split the key into the real key and the index

        // if the index isn't in the array, push it there (this keeps the same order)
        if (keys.indexOf(pair[1])===-1) {
        keys.push(pair[1])
        }

        // use object.assign to add the keys to the existing object in the right place in the array.
        arr[keys.indexOf(pair[1])] = Object.assign({}, arr[keys.indexOf(pair[1])], {[pair[0]]: input[key]}, { id: pair[1] })

        })





        share|improve this answer













        Oh, man... I just got beat. Here's my solution.



        let arr= [] // hold the final object array
        let keys = [] // temp item to hold the value of each key

        // iterate over each key
        Object.keys(input).forEach((key) => {
        let pair = key.split('-') // split the key into the real key and the index

        // if the index isn't in the array, push it there (this keeps the same order)
        if (keys.indexOf(pair[1])===-1) {
        keys.push(pair[1])
        }

        // use object.assign to add the keys to the existing object in the right place in the array.
        arr[keys.indexOf(pair[1])] = Object.assign({}, arr[keys.indexOf(pair[1])], {[pair[0]]: input[key]}, { id: pair[1] })

        })






        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered 48 mins ago









        tagyoureittagyoureit

        1065




        1065






























            draft saved

            draft discarded




















































            Thanks for contributing an answer to Stack Overflow!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid



            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.


            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55914053%2fhow-to-convert-array-of-objects-to-single-object-which-has-dynamic-key-in-typesc%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            Popular posts from this blog

            Taj Mahal Inhaltsverzeichnis Aufbau | Geschichte | 350-Jahr-Feier | Heutige Bedeutung | Siehe auch |...

            Baia Sprie Cuprins Etimologie | Istorie | Demografie | Politică și administrație | Arii naturale...

            Nicolae Petrescu-Găină Cuprins Biografie | Opera | In memoriam | Varia | Controverse, incertitudini...