如何将嵌套对象转换为嵌套结构的数组?

如何将嵌套对象转换为嵌套结构的数组?

对象转换为嵌套结构数组

给定一个嵌套的对象 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 的格式。

以上就是如何将嵌套对象转换为嵌套结构的数组?的详细内容,更多请关注其它相关文章!