平行数据结构和树状数据结构相互转化

**

功能实现: 平行数据结构转树状数据结构

**

**
 * 功能描述:将平铺数据结构转换为树状结构
 */

interface DataType {
	id: number; // 本节点id
	parentId: number; // 父节点id
	key: string;
	...
}

interface Tree {
	id: number; // 本节点id
	city: string;
	children: Tree[];
}




  // 树状数据,保存树状数据
  const treeList = []
  const map: Record<number, DataType> = {}; // id索引,通过id可以快速找到该节点
  
const arrToTree = (list: DataType[]) => {
  list.forEach(item => {
    if (!item.children) { // 补上children
      item.children = []
    }
    map[item.id] = item
  })
  list.forEach(item => {
    // 对于每个元素来说,先找他的上级,能找到,有上级,如果有,即将此数据方法上级的chidren中
    // 如果找不到,则没有上级,为单独存在的,即添加到treeList
    const parent = map[item.pid]
    // 如果存在则表示item不是最顶层的数据,代表其有上级
    if (parent) { // 如果有上级
      if (!parent.children) {
        parent.children = []
      }
      parent.children.push(item) // 将其添加到上级的children中
    } else {
      // 如果不存在 则是顶层数据
      treeList.push(item) // 没有上级的话添加到treeList中
    }
  })
  // 将判断后的树状数组返回出去
  return treeList
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值