一文带你吃透js处理树状结构数据的增删改查【转】

简介: 一文带你吃透js处理树状结构数据的增删改查【转】

theme: fancy

本文提到

问题描述:JS处理树状结构的增删改查

解决方案:

1、新增节点

2、删除节点

3、修改节点

4、查找节点

问题描述:JS处理树状结构的增删改查
最近在开发一个后台管理系统的权限管理模块,涉及到各种树状结构的数据处理逻辑,例如:增,删,改,查等;相比普通的数组结构数据,树状结构的处理就没有数组那么的直观,但是也没那么复杂,需要多一步——递归查找来对数据进行深度遍历操作,那么这里呢,博主也将开发过程中总结出来的方法分享给大家,一文带你吃透JS树装结构数据处理:

数据结构示例

  let data = [{
   
        id: 1,
        label: '一级 1',
        children: [{
   
          id: 4,
          label: '二级 1-1',
          children: [{
   
            id: 9,
            label: '三级 1-1-1'
          }, {
   
            id: 10,
            label: '三级 1-1-2'
          }]
        }]
      }, {
   
        id: 2,
        label: '一级 2',
        children: [{
   
          id: 5,
          label: '二级 2-1'
        }, {
   
          id: 6,
          label: '二级 2-2'
        }]
      }, {
   
        id: 3,
        label: '一级 3',
        children: [{
   
          id: 7,
          label: '二级 3-1'
        }, {
   
          id: 8,
          label: '二级 3-2'
        }]
      }];

解决方案:

1、新增节点

查找树装结构的指定节点,新增子节点,代码如下:

const appendNodeInTree = (id, tree, obj) => {
   
  tree.forEach(ele=> {
   
    if (ele.id === id) {
   
      ele.children ? ele.children.push(obj) : ele.children = [obj]
    } else {
   
      if (ele.children) {
   
        appendNodeInTree(id, ele.children, obj)
      }
    }
  })
  return tree
}

2、删除节点

查找树装结构的指定节点,删除节点,代码如下

const removeNodeInTree=(treeList, id)=> {
    // 通过id从数组(树结构)中移除元素
  if (!treeList || !treeList.length) {
   
    return
  }
  for (let i = 0; i < treeList.length; i++) {
   
    if (treeList[i].id === id) {
   
      treeList.splice(i, 1);
      break;
    }
    removeNodeInTree(treeList[i].children, id)
  }
}

3、修改节点

递归查找并修改某个节点的状态,代码如下:

  const updateNodeInTree=(treeList,id, obj)=> {
   
      if (!treeList || !treeList.length) {
   
        return;
      }
      for (let i = 0; i < treeList.length; i++) {
   
        if (treeList[i].id == id) {
   
          treeList[i]= obj;
          break;
        }
        updateNodeInTree(treeList[i].children,id,obj);
      }
    }

4、查找节点

递归查找树形节点的某个节点,代码:

const findNodeInTree = (data, key, callback) => {
   
      for (let i = 0; i < data.length; i++) {
   
        if (data[i].key == key) {
   
          return callback(data[i], i, data)
        }
        if (data[i].children) {
   
          findNodeInTree (data[i].children, key, callback)
        }
      }
    }

    // 所查找到的节点要存储的方法
    let Obj={
   }
    findNodeInTree(data, key, (item, index, arr) => {
   
      Obj = item
    })

    // 此时就是Obj对应的要查找的节点
    console.log(Obj)

总结

    本文介绍了js如何处理树装数据结构的增删改查,掌握以上函数,基本可以应对同样业务类型的数据处理,更多js处理数据问题方面的疑难杂症,【转载自:[国服第二切图仔](https://blog.csdn.net/m0_61243965/article/details/125580183"国服第二切图仔")】
相关文章
|
4天前
|
JavaScript 前端开发
Angular.js 应用中数据模式的删除操作实现
Angular.js 应用中数据模式的删除操作实现
16 0
|
3天前
|
前端开发 JavaScript 算法
JavaScript 中实现常见数据结构:栈、队列与树
JavaScript 中实现常见数据结构:栈、队列与树
|
4天前
|
存储 JSON JavaScript
Node.js 上开发一个 HTTP 服务器,监听某个端口,接收 HTTP POST 请求并处理传入的数据
Node.js 上开发一个 HTTP 服务器,监听某个端口,接收 HTTP POST 请求并处理传入的数据
13 0
|
5天前
|
设计模式 前端开发 JavaScript
AngularJS是一款由Google收购的JavaScript结构框架
【5月更文挑战第2天】AngularJS是Google收购的JavaScript框架,用于构建动态Web应用,基于MVC模式,强调模块化和双向数据绑定。它简化了视图与模型的同步,通过语义化标签和依赖注入提升开发效率。适用于复杂单页面应用(SPA),但不适合DOM操作密集型或性能要求极高的场景。
26 0
|
5天前
|
JSON JavaScript 前端开发
深入探讨javascript的流程控制与分支结构,以及js的函数
深入探讨javascript的流程控制与分支结构,以及js的函数
|
5天前
|
存储 JavaScript 前端开发
js的基本结构
【4月更文挑战第18天】js的基本结构
18 1
|
5天前
|
JavaScript 前端开发
js的结构
【4月更文挑战第16天】js的结构
19 4
|
5天前
|
JavaScript
EasyUi js 加载数据进下拉框combobox
EasyUi js 加载数据进下拉框combobox
|
5天前
|
JavaScript 前端开发
EasyUi js 加载数据表格DataGrid
EasyUi js 加载数据表格DataGrid
N..
|
5天前
|
存储 JavaScript 前端开发
JavaScript语言的基本结构
JavaScript语言的基本结构
N..
15 1