平铺的数组数据转化为树状结构

平铺的数组数据转化为树状结构

在做关于有树状构架的时候,我们需要将平铺的数组转化为树状结构,下面我会介绍一种简便的方式,有详细的注释,供大家参考!

传入数组结构为:{“id”:"",“pid”:"",“name”:""}

代码如下(示例):

/**
 * 将平铺的数据结构转换为树状结构
 */
  // 最终要产出的数组(树状数据)
  const treeList = []
  // 所有项都使用对象存储起来
  const map = {}
  // 建立映射关系:通过id快速找到对应的元素
  // map:
  // {
  //   "3129":{{"id":"","pid":"","name":""},chidren:[]}
  // }
  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
}
console.log(treeList)

此方法运用了两层循环。


总结

提示:本文只是提供正确思路,仅仅供给将方法传递,谢谢.

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值