根据某个节点的数据,向上查找所有的父级

const tree = [{

  id: 1,
  children: [
    {
      id: 3,
      children: [{
        id: 5
      }]
    },
    {
      id: 4
    }
  ]

},
{
  id: 7,
  children: [
    {
      id: 8
    }
  ]
}

]

const arr = []
const getParentIds = function (id, tree, arr) {
  for (const i = 0, length = tree.length; i < length; i++) {

    const currentNode = tree[i]

    if (currentNode.id === id) {
      arr.push(id)
      return true
    } else {
      if (currentNode.children && currentNode.children.length) {
        const find = getParentIds(id, currentNode.children, arr)
        if (find) {
          arr.push(currentNode.id)
          return true
        }
      } else {
        return false
      }
    }

  }

}


getParentIds(8, tree, arr)
console.log(arr)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值