如何将嵌套对象转换为嵌套结构的数组?
对象转换为嵌套结构数组
给定一个嵌套的对象 obj,要求将其转换为一个嵌套结构的数组 list。每个数组项代表 obj 中的一个键及其对应的值列表,转换为以下格式:
const list = [ { id: 1, // 自动生成的 ID name: 'a', // 对象的键 childList: [ { id: 2, name: 'a1' }, // 子数组中的第一项 { id: 3, name: 'a2' }, // 子数组中的第二项 ], }, { id: 4, // 自动生成的 ID name: 'b', // 对象的键 childList: [ { id: 5, name: 'b1' }, // 子数组中的第一项 { id: 6, name: 'b2' }, // 子数组中的第二项 { id: 7, name: 'b3' }, // 子数组中的第三项 ], }, ];
解决方案:
使用 Object.entries() 和 reduce() 方法。
将 obj 的键值对转换为数组:
let obj = { "a": [ "a1", "a2" ], "b": [ "b1", "b2", "b3" ] }; let entries = Object.entries(obj);
使用 reduce() 将每个键值对转换为 list 项:
entries.reduce((acc, [name, val]) => { acc.push({ id: id++, name, childList: val.map(name => ({ id: id++, name })), }); return acc; }, []);
- id 是自动生成的 ID。
- name 是键值对的键。
- childList 是值数组,每个值已转换为具有自动生成 ID 和值的子项。
最终,acc 数组将采用 list 的格式。
以上就是如何将嵌套对象转换为嵌套结构的数组?的详细内容,更多请关注其它相关文章!