扁平数组转化分类树

使用下列数组生成一个分类树(数组中每项中的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);

在这里插入图片描述

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

江拥羡橙

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值