鑒于此源物件:
const src = { a: [1, 2, 3]} }
我想將其轉換為代表所有組合的物件陣列(3):
[{a: 1}, {a: 2}, {a: 3}]
我目前擁有的代碼有效,但感覺不雅:
const arrPairs = [];
Object.keys(src).map((el) => {
src[el].forEach(element => {
arrPairs.push({[el]: element});
});
});
我有一種感覺,map/reduce 的某種組合會做得更干凈,我只是想不通。
uj5u.com熱心網友回復:
您可以遍歷條目.flatMap并將每個值映射到其關聯物件。
const src = { a: [1, 2, 3],
b: [4, 5, 6, 7],
c: [8, 9, 10, 11, 12] };
const result = Object.entries(src)
.flatMap(([key, arr]) => arr.map(val => ({[key]: val})));
console.log(result);
uj5u.com熱心網友回復:
您可以使用reduce和map輕松實作結果
const src = {
a: [1, 2, 3],
};
const result = Object.keys(src).reduce(
(acc, curr) => [...acc, ...src[curr].map((val) => ({ [curr]: val }))],
[]
);
console.log(result);
轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/342678.html
標籤:javascript 数组
