登录
首页 >  文章 >  前端

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

时间:2024-11-06 08:15:52 369浏览 收藏

文章不知道大家是否熟悉?今天我将给大家介绍《如何将嵌套对象转换为嵌套结构的数组? 》,这篇文章主要会讲到等等知识点,如果你在看完本篇文章后,有更好的建议或者发现哪里有问题,希望大家都能积极评论指出,谢谢!希望我们能一起加油进步!

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

对象转换为嵌套结构数组

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

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《如何将嵌套对象转换为嵌套结构的数组? 》文章吧,也可关注golang学习网公众号了解相关技术文章。

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>