当前位置:首页 » 《随便一记》 » 正文

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

27 人参与  2022年07月26日 08:15  分类 : 《随便一记》  评论

点击全文阅读


目录

问题描述: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处理数据问题方面的疑难杂症,推荐查看博主之前总结的文章,喜欢博主的朋友可以给博主点个关注,点关注,不迷路,博主带你上高速~~

直面JavaScript数据处理的5个常见疑难杂症_国服第二切图仔的博客-CSDN博客本文介绍了JavaScript开发过程中常见的5种数据处理问题——数组的增删改查、数组去重、数组排序,平级结构转树装结构,数组对象去重合并等等并提供了对应的解决思路,基本覆盖了日常开发过程中的使用需求, 阅读本片文章可以大大提升你的javaScript基本功,在收到开发需求时,能快速响应,并给出解决方案。......https://blog.csdn.net/m0_61243965/article/details/125084028?spm=1001.2014.3001.5502


点击全文阅读


本文链接:http://m.zhangshiyu.com/post/43811.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

最新文章

  • 难渡红尘,爱恨随风去小说精彩章节免费试读_陆梨初徐慕凡陆总章节世界观揭秘篇‌
  • 黄泉情难渡爽文(叶北宸凤念安),黄泉情难渡爽文
  • [夫人她要对暗号,世子他在***]小说精彩节选试读_[舒妗月洛知珩]章节彩蛋限时释出‌
  • 全书浏览小姑子要重新养一遍自己,让我给她买百万豪车(江梦瑶林霜)_小姑子要重新养一遍自己,让我给她买百万豪车(江梦瑶林霜)全书结局
  • 人面桃花长相忆纯净版(阮雾梨闻砚辞)全书免费_(阮雾梨闻砚辞)人面桃花长相忆纯净版后续(阮雾梨闻砚辞)
  • 等风等雨等不到你现已上架(夏语栀祁墨寒许青瑶)_等风等雨等不到你现已上架
  • 别后不知君回首(程十安傅临州)_别后不知君回首
  • 顾书程江仪(第九十九次被绑架失忆后,我觉醒了+后续+结局)_顾书程江仪列表_笔趣阁(第九十九次被绑架失忆后,我觉醒了+后续+结局)
  • 野火吻过薄情玫瑰全文免费无弹窗阅读_笔趣阁_魏景辰傅雯杉傅家全文免费无弹窗阅读_笔趣阁
  • 别后不知君回首全书+后续(程十安傅临州)列表_别后不知君回首全书+后续(程十安傅临州)别后不知君回首全书+后续在线
  • 人面桃花长相忆+后续+结局(阮雾梨闻砚辞阮见微)列表_人面桃花长相忆+后续+结局(阮雾梨闻砚辞阮见微)人面桃花长相忆+后续+结局在线
  • 南风等不来候鸟结局+番外全书+后续+结局(沈南风苏雨柔)列表_南风等不来候鸟结局+番外(沈南风苏雨柔)南风等不来候鸟结局+番外全书+后续+结局在线

    关于我们 | 我要投稿 | 免责申明

    Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1