将平铺数据转换为树形结构

该文章介绍了一个JavaScript函数,用于将包含ID和PID的平铺数组转换为树形数据结构。函数通过遍历数组,将每个元素根据其父ID(pid)添加到对应的父节点的children数组中,没有父节点的元素则添加到根节点数组treeArr中。
摘要由CSDN通过智能技术生成
// 平铺数组转树
export function tranListToTreeData(arr) {
  const treeArr = []
  const map = {}
  arr.forEach(item => {
    item.children = []
    map[item.id] = item
  })
  /* console.log(map)
     对arr进行循环,对每一个元素item,如果
     1.item有上级元素pItem,把item添加到pItem.children
     2.item没有上级元素(根据item.pid去找,找不到元素),添加到treeArr
    */
  arr.forEach(item => {
    const pItem = map[item.pid]
    // console.log(pItem);
    // console.log(item);
    if (pItem) {
      pItem.children.push(item)
    } else {
      treeArr.push(item)
    }
  })

  return treeArr
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值