相关文章推荐
果断的可乐  ·  C#之解决 ...·  3 月前    · 
满身肌肉的人字拖  ·  ​ ...·  1 年前    · 
千杯不醉的香槟  ·  Flask ...·  1 年前    · 

JS树形结构根据id获取父级节点元素的示例代码

作者:战立标

这篇文章主要介绍了JS树形结构根据id获取父级节点元素,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
// 传入 id、树形结构数据
export function getParentTree(id, tree) {
  let arr = [] //要返回的数组
  for (let i = 0; i < tree.length; i++) {
    let item = tree[i]
    arr = []
    arr.push(item) //保存当前节点id
    if (id== item.id) {
      //判断当前id是否是默认id
      return arr //是则退出循环、返回数据
    } else {
      //否则进入下面判断,判断当前节点是否有子节点数据
      if (item.children && item.children.length > 0) {
        //合并子节点返回的数据
        arr = arr.concat(getParentTree(id, item.children ? item.children : []))
        console.log(arr)
        if (arr.map(item2 => (item2 ? item2.id : '')).includes(id)) {
          //如果当前数据中已包含默认节点,则退出循环、返回数据
          return arr
const treeData = [{
  name: '1',
  id: 1,
  children: [{
    name: '1-1',
    id: 2,
    children: [{
      name: '1-1-1',
      id: 4,
    name: '1-2',
    id: 3,
    children: [{
      name: '1-2-1',
      id: 5,
  name: '2',
  id: 6,
  children: [{
    name: '2-1',
    id: 7,
    children: [{
      name: '2-1-1',
      id: 9,
    name: '2-2',
    id: 8,
    children: [{
      name: '2-2-1',
      id: 10,
console.log(getParentTree(5, treeData))

到此这篇关于JS树形结构根据id获取父级节点元素的文章就介绍到这了,更多相关js获取父级节点元素内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
  • JavaScript中的new操作符的具体使用
    JavaScript中的new操作符的具体使用
    2023-05-05
  • JavaScript如何防止页面退格键回退
    JavaScript如何防止页面退格键回退
    2023-05-05
  • 实现抖音两个旋转小球的loading技巧实例
    实现抖音两个旋转小球的loading技巧实例
    2023-05-05
  • JavaScript实现读取上传视频文件的时长和第一帧画面过程讲解
    JavaScript实现读取上传视频文件的时长和第一帧画面过程讲解
    2023-05-05
  • JS树形结构根据id获取父级节点元素的示例代码
    JS树形结构根据id获取父级节点元素的示例代码
    2023-05-05
  • js保留两位小数最简单的实现方法
    js保留两位小数最简单的实现方法
    2023-05-05
  • js中.sort()函数的常见用法与高级操作
    js中.sort()函数的常见用法与高级操作
    2023-05-05
  • js获取今天、昨天、明天的日期函数代码
    js获取今天、昨天、明天的日期函数代码
    2023-05-05
  • 美国设下计谋,用娘炮文化重塑日本,已影响至中国
    美国设下计谋,用娘炮文化重塑日本,已影响至中国
    2021-11-19
  • 时空伴随者是什么意思?时空伴随者介绍
    时空伴随者是什么意思?时空伴随者介绍
    2021-11-09
  • 工信部称网盘企业免费用户最低速率应满足基本下载需求,天翼云盘回应:坚决支持,始终
    工信部称网盘企业免费用户最低速率应满足基本下载需求,天翼云盘回应:坚决支持,始终
    2021-11-05
  • 2022年放假安排出炉:五一连休5天 2022年所有节日一览表
    2022年放假安排出炉:五一连休5天 2022年所有节日一览表
    2021-10-26
  • 电脑版 - 返回首页

    2006-2023 脚本之家 JB51.Net , All Rights Reserved.
    苏ICP备14036222号