js递归获取子节点所有父节点

淺唱寂寞╮ 提交于 2020-04-07 17:55:03

起因:业务中用到了element级联选择器,级联的反显需要这样的数据[id(父),id(父),id(当前选中)],由于后端的无能,不会遍历找所有关联的父节点,只能由前端来做,所以就写了一个简单的递归。

 findAncestry (arr, id) {
      var temp = []
      var forFn = function (list, id) {
        for (var i = 0; i < list.length; i++) {
          var item = list[i]
          if (item.id === id) {
            temp.push(item)
            forFn(list, item.pid)
            break
          } else {
            if (item.children) {
              forFn(item.children, id)
            }
          }
        }
      }
      forFn(arr, id)
      return temp
 }

 

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!