当前位置: 首页 > news >正文

js 将一维数组转换成树形结构的方法

一维数组的数据结构,如下
const flatArray = [
{ id: 1, parent_id: null, name: ‘root1’ },
{ id: 2, parent_id: null, name: ‘root2’ },
{ id: 3, parent_id: 1, name: ‘child1’ },
{ id: 4, parent_id: 2, name: ‘child2’ },
{ id: 5, parent_id: 3, name: ‘grandchild1’ },
{ id: 6, parent_id: 4, name: ‘grandchild2’ },
];
方式1:使用map 结构,for循环查找,推荐,性能比较好

  function arrayToTree(items) {const map = new Map();const result = [];//创建映射,方便查找items.forEach((item) => {map.set(item.id, { ...item, children: [] });});//遍历全部节点,构建treeitems.forEach((item) => {const node = map.get(item.id);if (item.parent_id) {//存在父级节点const parent_node = map.get(item.id);parent_node.children.push(node);} else {//根节点result.push(node);}});return result;}

方式2:使用递归的方式,从根节点开始,查找每个节点的子节点

  //递归,从根节点开始,查找每个节点的子节点function arrayToTree2(items, parent_id) {//第一次,全部根节点return items.filter((item) => {return item.parent_id == parent_id;}).map((item) => {//查找根节点下面的子节点return {...item,children: arrayToTree2(items, item.id),};});}

方式3:将上面两种方式结合起来,使用map做映射,同时使用递归(先筛选出根节点,再递归查找子节点)

  function arrayToTree3(items) {const map = new Map();//创建映射,方便查找items.forEach((item) => {map.set(item.id, { ...item, children: [] });});//递归函数function buildTree(node) {items.filter((item) => {if (item.parent_id == node.id) {//是查找节点的子节点const child = map.get(item.id);//查找子节点的子节点node.children.push(buildTree(child));}});return node;}//先筛选出根节点数组,用递归查找根节点的子节点return items.filter((item) => item.parent_id === null).map((item) => buildTree(map.get(item.id)));}
http://www.lryc.cn/news/467845.html

相关文章:

  • HarmonyOS NEXT开发实战:实现高效下拉刷新与上拉加载组件(二)刷新核心逻辑与空页面集成
  • Crawler4j在多线程网页抓取中的应用
  • 【无标题】Django转化为exe,app
  • HTML5_标签_各类表格的实现
  • C语言数据结构之单向链表(SingleList)
  • 【银河麒麟高级服务器操作系统实例】金融行业TCP连接数猛增场景的系统优化
  • 详解Java的类文件结构(.class文件的结构)
  • 爆肝整理14天!AI工具宝藏合集
  • 高效库存管理:金蝶云星空与管易云的盘亏单对接方案
  • 小鹏汽车股价分析:看涨信号已出现,技术指标显示还有40%的上涨空间
  • c语言指针详解2
  • Chrome DevTools 二: Performance 性能面板
  • 渠道推广如何识别与防止虚假流量?
  • Keil C51 9.61__官网“最新版“下载、安装及相关提示( 保姆级教程, 安装过程详解, 附安装包 )
  • 二进制搭建 Kubernetes v1.20
  • 我希望,你把篮球和鸡联系起来想一想。。。
  • STM32 ADC介绍
  • JavaWeb合集12-Redis
  • 【C++】在Windows中使用Boost库——实现TCP、UDP通信
  • 怎么提取pdf的某一页?批量提取pdf的某一页的简单方法
  • Github优质项目推荐(第八期)
  • 快读快写模板
  • make_blobs函数
  • 特斯拉Optimus:展望智能生活新篇章
  • 基于Leaflet和SpringBoot的全球国家综合检索WebGIS可视化
  • 【Linux】/usr/share目录
  • Java中如何应用序列化 serialVersionUID 版本号呢?
  • 面部识别技术:AI 如何识别人脸
  • 全面解析文档对象模型(DOM)及其操作(DOM的概念与结构、操作DOM节点、描述DOM树的形成过程、用DOMParser解析字符串为DOM对象)
  • 字符串使用方法: