扁平数组转化分类树

使用下列数组生成一个分类树(数组中每项中的pid是父节点的id,pid:0表示顶层,pid:1,表示这个节点属于id为1的节点,children该节点的子节点数组)

const jsona = [{"ID": 1,"CreatedAt": "2022-05-26T15:59:53.726+08:00","UpdatedAt": "2022-05-26T15:59:53.726+08:00","creationDate": "","title": "分类","pid": "0","children": null
}, {"ID": 2,"CreatedAt": "2022-05-26T16:00:06.96+08:00","UpdatedAt": "2022-05-26T16:00:06.96+08:00","creationDate": "","title": "容量","pid": "4","children": null
}, {"ID": 3,"CreatedAt": "2022-05-26T16:00:14.007+08:00","UpdatedAt": "2022-05-26T16:00:14.007+08:00","creationDate": "","title": "颜色","pid": "4","children": null
}, {"ID": 4,"CreatedAt": "2022-05-26T16:00:19.643+08:00","UpdatedAt": "2022-05-26T16:00:19.643+08:00","creationDate": "","title": "手机","pid": "1","children": null
}, {"ID": 5,"CreatedAt": "2022-05-26T16:00:29.451+08:00","UpdatedAt": "2022-05-26T16:00:29.451+08:00","creationDate": "","title": "电脑","pid": "1","children": null
}, {"ID": 6,"CreatedAt": "2022-05-26T16:00:38.198+08:00","UpdatedAt": "2022-05-26T16:00:38.198+08:00","creationDate": "","title": "128G","pid": "2","children": null
}, {"ID": 7,"CreatedAt": "2022-05-26T16:00:44.32+08:00","UpdatedAt": "2022-05-26T16:00:44.32+08:00","creationDate": "","title": "256G","pid": "2","children": null
}, {"ID": 8,"CreatedAt": "2022-05-26T16:00:55.368+08:00","UpdatedAt": "2022-05-26T16:00:55.368+08:00","creationDate": "","title": "金色","pid": "3","children": null
}, {"ID": 9,"CreatedAt": "2022-05-26T16:01:01.751+08:00","UpdatedAt": "2022-05-26T16:01:01.751+08:00","creationDate": "","title": "银色","pid": "3","children": null
}, {"ID": 10,"CreatedAt": "2022-05-31T10:49:24.062+08:00","UpdatedAt": "2022-05-31T10:49:24.062+08:00","creationDate": "","title": "macbook Air 2022","pid": "5","children": null
}, {"ID": 12,"CreatedAt": "2022-05-31T10:49:47.497+08:00","UpdatedAt": "2022-05-31T10:49:47.497+08:00","creationDate": "","title": "m1","pid": "11","children": null
}, {"ID": 13,"CreatedAt": "2022-05-31T10:50:00.801+08:00","UpdatedAt": "2022-05-31T10:50:00.801+08:00","creationDate": "","title": "i5","pid": "11","children": null
}, {"ID": 15,"CreatedAt": "2022-05-31T10:51:22.369+08:00","UpdatedAt": "2022-05-31T10:51:22.369+08:00","creationDate": "","title": "CPU","pid": "10","children": null
}, {"ID": 16,"CreatedAt": "2022-05-31T10:51:29.098+08:00","UpdatedAt": "2022-05-31T10:51:29.098+08:00","creationDate": "","title": "M1","pid": "15","children": null
}, {"ID": 17,"CreatedAt": "2022-05-31T10:51:37.599+08:00","UpdatedAt": "2022-05-31T10:51:37.599+08:00","creationDate": "","title": "I7","pid": "15","children": null
}, {"ID": 18,"CreatedAt": "2022-05-31T10:51:48.028+08:00","UpdatedAt": "2022-05-31T10:51:48.028+08:00","creationDate": "","title": "内存","pid": "10","children": null
}, {"ID": 19,"CreatedAt": "2022-05-31T10:51:54.358+08:00","UpdatedAt": "2022-05-31T10:51:54.358+08:00","creationDate": "","title": "8G","pid": "18","children": null
}, {"ID": 20,"CreatedAt": "2022-05-31T10:51:59.569+08:00","UpdatedAt": "2022-05-31T10:51:59.569+08:00","creationDate": "","title": "16G","pid": "18","children": null
}]

思路

为了将上述数组转换成分类树结构,我们可以使用递归方法来构建树形数据结构。主要步骤包括:

  1. 创建一个映射表,用于快速查找每个节点。
  2. 遍历数组,根据 pid 值将子节点添加到其父节点的 children 数组中。
  3. 查找 pid 为 0 的节点作为根节点。

代码实现

function buildTree(data) {const map = {};const rootNodes = [];// 遍历所有数据,构建映射表data.forEach(item => {map[item.ID] = { ...item, children: [] };});// 再次遍历数据,构建树形结构data.forEach(item => {const node = map[item.ID];if (item.pid === '0') {rootNodes.push(node);} else {const parent = map[item.pid];if (parent) {parent.children.push(node);}}});return rootNodes;
}
const treeData = buildTree(jsona);
// 输出结果
console.log(treeData);

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/878693.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用大型语言模型进行监督微调(SFT)

大型语言模型(LLMs)通常经过几个阶段的训练,包括预训练和几个微调阶段;请参见下文。尽管预训练很昂贵(即需要数十万美元的计算成本),但相比之下,微调LLM(或进行上下文学习…

应用商店优化(ASO)的四大误区

应用商店优化 (ASO) 是移动营销中最重要的部分之一,可以帮助开发人员吸引自然流量并在应用推广方面取得预期效果。近年来ASO优化在开发者中越来越受欢迎。虽然它已经证明了其有效性和对应用成功的影响力,但尽管如此仍然存在与ASO相关的误解,导…

Day-04-QFile打开文件的两种方式

一、UI界面设置两个按键&#xff0c;并直接转到槽函数 二、两种代码展示 #include <QFile> #include <QDebug>//此两种方式中调用函数&#xff0c;应包含的头文件void Widget::on_btnReadFile01_clicked()//第一种打开方式 {//1. 打开文件QFile file;file.setFile…

ARM发布新一代高性能处理器N3

简介 就在2月21日&#xff0c;ARM发布了新一代面向服务器的高性能处理器N3和V3&#xff0c;N系列平衡性能和功耗&#xff0c;而V系列则注重更高的性能。此次发布的N3&#xff0c;单个die最高32核&#xff08;并加入到CCS&#xff0c;Compute Subsystems&#xff0c;包含Core&a…

【Unity案例】搭建射击系统与UI

上期将基础的移动系统搭建完毕后就可以开始搭建更加复杂的系统部分了 前排提示&#xff0c;由于一开始仅思考如何完成操作相关功能&#xff0c;以至于到后面重构稍微有些困难&#xff0c;继续写下去恐成屎山&#xff0c;故在搭完射击和武器UI后不再继续泛化到敌人和敌人状态机…

本地Gitblit使用

首先创建一个本地的gitblit的服务&#xff0c;创建流程如下&#xff1a; 【GitBlit】Windows搭建Git服务器详细教程_搭建gitblit服务-CSDN博客 GitBlit的使用教程-CSDN博客 创建好一个仓库后&#xff0c;分配好用户权限&#xff0c;再将项目拉下来&#xff0c;这里是再visua…

零信任赋予安全牙齿,AI促使它更锋利

距离上次写关于安全的文字已经过去了很久很久&#xff0c;久到上次看到的AI还停留在TTS、ASR等最初的语音交互搜索类似的各种智能音箱以及通过关键字匹配的基于知识库的聊天的机器人。之后的几年各种视觉识别遍地开花&#xff0c;AI四小龙在人脸识别上成熟应用&#xff0c;再然…

浏览器百科:网页存储篇-如何在Chrome打开localStorage窗格(五)

1.引言 在前面的章节中&#xff0c;我们详细介绍了 localStorage 的基本概念、特性及其常用方法&#xff0c;帮助开发者在网页应用中实现数据的持久化存储。为了更好地管理和调试这些存储的数据&#xff0c;了解如何打开和使用浏览器的 localStorage 窗格是非常重要的。本篇文…

科研绘图系列:R语言差异基因四分图(Quad plot)

介绍 四分图(Quad plot)是一种数据可视化技术,通常用于展示四个变量之间的关系。它由四个子图组成,每个子图都显示两个变量之间的关系。四分图的布局通常是2x2的网格,每个格子代表一个变量对的散点图。 在四分图中,通常: 第一个子图显示变量A和B的关系。第二个子图显示…

海外云服务器安装 MariaDB10.6.X (Ubuntu 18.04 记录篇二)

本文首发于 秋码记录 MariaDB 的由来&#xff08;历史&#xff09; 谈起新秀MariaDB&#xff0c;或许很多人都会感到陌生吧&#xff0c;但若聊起享誉开源界、业界知名的关系型数据库——Mysql&#xff0c;想必混迹于互联网的人们&#xff08;coder&#xff09;无不知晓。 其…

信捷 XD PLC 位软元件

位软元件的种类相对简单&#xff0c;一般为常见的 X、Y、M、HM、S、HS、T、HT、C、HC&#xff0c; 除此之外&#xff0c; 还可由寄存器中的某一位来表示。 1&#xff09;继电器 ⚫ 输入继电器 X&#xff0c;八进制表示法。 ⚫ 输出继电器 Y&#xff0c;八进制表示法。 ⚫ …

SQL语言的规则和规范

规则 是什么呢&#xff0c;规则就是我们最基本&#xff0c;每时每刻都要遵守的比如人行道靠右&#xff0c;不能逆行&#xff0c; 规范 呢就是锦上添花&#xff0c;如果你不这么做&#xff0c;是不那么道德&#xff0c;不那么好的&#xff0c;就像小学生见到老师要问好&#…

C++11(1)

目录 前言 小故事 C11优势 统一的列表初始化 1.{}初始化 2. std::initializer_list 声明 1.auto 2.decltype 3.nullptr 前言 小故事 1998 年是 C 标准委员会成立的第一年&#xff0c;本来计划以后每 5 年视实际需要更新一次标准&#xff0c; C 国际 标准委员会在研究…

Axure制作圆球在区域范围内移动效果的案例

在Axure RP中&#xff0c;我们可以通过设置多个交互动作和动态面板来创建复杂的动画效果&#xff0c;比如实现一个圆球在指定区域内通过八个方向按钮控制移动的效果。以下是一个详细的步骤介绍&#xff0c;帮助你理解并制作这一效果。 预览&#xff1a; https://1zvcwx.axshare…

简述CCS平面线性光源

光源在机器视觉系统中起着重要作用&#xff0c;不同环境、场景及应用合适光源都不一样&#xff0c;今天我们来看看LFX3-PT系列平面线性光源。它是最适合检测镜面物体的凹凸,外壳小巧的光源。备有根据检测条件可选的2种线间距。1mm型&#xff08;型号末尾&#xff1a;A&#xff…

idea一键自动化部署项目

文章目录 前言一、 IDEA插件安装1. 首先下载 Alibaba Cloud Toolkit 插件2. 插件下载完成后重启IDEA 二、SpringBoot项目准备1. pom.xml 文件2. controller3. 启动类 三、SpringBoot项目jar包部署1. Alibaba Cloud Toolkit 插件服务器配置2. 主机 IP、用户名、密码 点击测试链接…

日志系统(最新版)

基础知识 日志&#xff0c;由服务器自动创建&#xff0c;并记录运行状态&#xff0c;错误信息&#xff0c;访问数据的文件。 同步日志&#xff0c;日志写入函数与工作线程串行执行&#xff0c;由于涉及到I/O操作&#xff0c;当单条日志比较大的时候&#xff0c;同步模式会阻塞…

file | 某文件夹【解耦合】下的文件查找功能实现及功能单元测试

文件查找工具 概要思路OS模块 --- 学习版os.getcwd()os.path.dirname(os.getcwd())os.path.dirname() 和 os.path.basename() OS模块 — 实战版单元测试解耦合 概要 梳理业务主逻辑&#xff1a; 查看存放被采集JSON数据的文件夹内的文件列表【所有 包含文件夹下的文件夹下的文…

【Anaconda】修改jupyter notebook默认打开的工作目录、jupyter notebook快捷键

jupyter notebook快捷键 针对单元格的颜色蓝色命令行模式绿色编辑模式 两种模式的切换编辑模式切换到命令行模式 >>> esc键命令行模式切换到编辑模式 >>> 鼠标左键或者直接按enter键1.标题的书写方式1:1.esc进入命令行模式2.按m键3.写内容4.运行单元格即可方…

SprinBoot+Vue健康管管理微信小程序的设计与实现

目录 1 项目介绍2 项目截图3 核心代码3.1 Controller3.2 Service3.3 Dao3.4 application.yml3.5 SpringbootApplication3.5 Vue3.6 uniapp代码 4 数据库表设计5 文档参考6 计算机毕设选题推荐7 源码获取 1 项目介绍 博主个人介绍&#xff1a;CSDN认证博客专家&#xff0c;CSDN平…