如何将扁平对象数组转换为具有层级嵌套的树状结构?

如何将扁平对象数组转换为具有层级嵌套的树状结构?

js数据整理

问题: 如何将给定数据结构(扁平对象数组)转换为具有层级嵌套的树状结构?

数据示例:

[{"id": 1,"key": "","name": "系统管理","level": 1,"type": 1,"icon": "","code": "a001","parentcode": "","num": "a-1",},{"id": 7,"key": "","name": "日志管理","level": 1,"type": 1,"icon": "","code": "a004","parentcode": "","num": "a-7",},{"id": 8,"key": "roleadd","name": "角色管理","level": 2,"type": 1,"icon": "","code": "b001","parentcode": "a001","num": "1-1",},{"id": 14,"key": "logomanage","name": "日志管理","level": 2,"type": 1,"icon": null,"code": "e001","parentcode": "a004","num": "1-1",}]

登录后复制

期望结果:

[{"id": 1,"key": "","name": "系统管理","level": 1,"type": 1,"icon": "","code": "a001","parentcode": "","num": "a-1","children": [{"id": 8,"key": "roleadd","name": "角色管理","level": 2,"type": 1,"icon": "","code": "b001","parentcode": "a001","num": "1-1",}]},{"id": 7,"key": "","name": "日志管理","level": 1,"type": 1,"icon": "","code": "a004","parentcode": "","num": "a-7","children": [{"id": 14,"key": "logomanage","name": "日志管理","level": 2,"type": 1,"icon": null,"code": "e001","parentcode": "a004","num": "1-1",}]}]

登录后复制

回答:

可以使用递归算法将扁平数据转换为树状结构。以下代码演示了如何实现:

let list = res[0]["__menus__"];function transformData(data) {  const result = [];  for (const item of data) {    const children = transformData(      data.filter((d) => d.parentCode === item.code)    );    if (children.length) {      result.push({ ...item, children });    } else {      result.push(item);    }  }  return result;}console.log(transformData(list));

登录后复制

将给定的数据作为 res[0][‘__menus__’] 传递给 transformdata 函数,该函数会递归循环数据,为具有相同父级代码的项目创建嵌套的树状结构。最终,函数返回一个具有层级嵌套的树状结构新数组,符合期望的结果。

以上就是如何将扁平对象数组转换为具有层级嵌套的树状结构?的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2654527.html

(0)
上一篇 2025年3月7日 09:27:23
下一篇 2025年2月28日 21:27:08

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论