树形表格的使用——配置DOM结构的延用[若依tree和普通树形结构的通用]

2023-11-09 19:30

本文主要是介绍树形表格的使用——配置DOM结构的延用[若依tree和普通树形结构的通用],希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

树形表格的使用——配置DOM结构的延用[若依tree和普通树形结构的通用]

文章目录

      • 树形表格的使用——配置DOM结构的延用[若依tree和普通树形结构的通用]
        • 技术:
        • 背景:
        • 一、树形结构的设计
        • 二、新增节点的完成
        • 三、删除指定节点
        • 四、编辑节点的完成

技术:
架构:elemen-admin-beautiful,
引用:若依前后端分离版树形表格
element-ui 树形结构
背景:
业务需在web同app端回显树形数据结构的报告预览,经商讨确认使用树形结构的表格配置相关Dom节点,本文将记载个人完成树形结构的部分point

预览效果图:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qW2SevlP-1598070798263)(http://mmbiz.qpic.cn/mmbiz_jpg/qRJazDfIbDyvFXT4LSnd8ibEh1iaTxf4F1fvTlZ73PYSYiaOe05YPEWRFWt9MbhfEANQ33H1oHWpGb4d4SSNJh2jQ/0)]

节点新增

一、树形结构的设计

在设计该数据的时候,本人就子节点中需要逐一配置的事项,追溯单一子节点的效率方面,参照若依前后端分离版结构,规定父节点和子节点的children统一为[],通过menuIdparentId绑定形成nodeList,随后经handleTree()转化为树形表格所需结构[即子节点包含在父节点对象的children list中]使用。

如图所示:

一维list转化为tree树形结构的代码如下:

 	  /*** 构造树型结构数据* @param {*} data 数据源* @param {*} id id字段 默认 'id'* @param {*} parentId 父节点字段 默认 'parentId'* @param {*} children 孩子节点字段 默认 'children'* @param {*} rootId 根Id 默认 0*/handleTree(data, id, parentId, children, rootId) {id = id || "id";parentId = parentId || "parentId";children = children || "children";rootId = rootId || 0;//对源数据深度克隆const cloneData = JSON.parse(JSON.stringify(data));//循环所有项const treeData = cloneData.filter((father) => {let branchArr = cloneData.filter((child) => {//返回每一项的子级数组return father[id] === child[parentId];});branchArr.length > 0 ? (father.children = branchArr) : "";//返回第一层return father[parentId] === rootId;});return treeData != "" ? treeData : data;},
二、新增节点的完成

如前图(增加节点)所示,本人将其中含有配置的表单contentFom在每次新增时添加至nodeList数组中,随后将其重置,最后利用上面的handleTree的方法将nodeList转化为树形结构特征的dataList数组

主要代码如下:

// 新增节点
this.nodeList.push(this.contentForm);
// 表单重置
this.contentForm = this.$options.data().contentForm;
this.dataList = this.handleTree(this.nodeList, "menuId");
三、删除指定节点

如果使用树形结构的List这一步操作可移至element-ui树形控件——>自定义节点内容中查看详细删除

element-ui 删除源码:

remove(node, data) {const parent = node.parent;const children = parent.data.children || parent.data;const index = children.findIndex(d => d.id === data.id);children.splice(index, 1);
},

Link:

本文探讨nodeList一维带有父子级关系数组的删除方法,删除核心使用递归算法完成,主要思想:

定义一个del_arr数组主要用于记录需要删除的所有节点索引[基于一维父子级关系的数组],通过对nodeList遍历完成删除。需要注意的是两个点:1.删除一个父级的时候,需要递归查找子级,这样不会遗漏子级存在子级的情况;2.获取到所有需要删除的节点索引组成的数组del_arr时,需要注意,不能顺序遍历删除,否则会打乱nodeList的索引,可以将该索引数组倒序排列之后完成相应操作

主要代码如下:

/** 删除按钮操作 */handleDelete(row) {this.del_arr = [];this.$confirm('是否确认删除目录名称为"' + row.nodeTitle + '"的节点?').then((_) => {if (this.nodeList.length != 0) {// 删除当前行this.nodeList.forEach((item, index) => {if (item.menuId === row.menuId) {this.del_arr.push(index);}});// 删除子代行this.findNodeChild(row.menuId);// 倒序this.del_arr.sort((a, b) => {return b - a;});this.del_arr.forEach((item, index) => {this.nodeList.splice(item, 1);});this.dataList = this.handleTree(this.nodeList, "menuId");}}).catch((_) => {});},

递归方法findNodeCHild()

// 寻找子代节点findNodeChild(child_id) {this.nodeList.forEach((item, index) => {if (item.parentId == child_id) {this.del_arr.push(index);this.findNodeChild(item.menuId); // 注意此时的参数}});},
四、编辑节点的完成

阅读至此,感谢垂阅.

对于编辑节点,如若好的想法,请多加指教

本文拙见为:通过树形表格编辑按钮获取节点信息,利用menuId获取当前的节点对象,根据配置或者编辑修改相应的属性值,最后重新渲染树,完成编辑

主要代码如下:

 this.nodeList.map((item, index) => {if (item.menuId == this.tmpID) {item.nodeTitle = this.contentForm.nodeTitle;}});
// 节点重置
this.nodeReset();
this.dataList = this.handleTree(this.nodeList, "menuId");

最后,Kyle分享一句话送给各位:

不要因害怕冒险而踟蹰不前,而要为创造伟大提供可能

rm.nodeTitle;
}
});
// 节点重置
this.nodeReset();
this.dataList = this.handleTree(this.nodeList, “menuId”);

最后,Kyle分享一句话送给各位:不要因害怕冒险而踟蹰不前,而要为创造伟大提供可能Good Lucky,Bro!

这篇关于树形表格的使用——配置DOM结构的延用[若依tree和普通树形结构的通用]的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/378127

相关文章

Python虚拟环境终极(含PyCharm的使用教程)

《Python虚拟环境终极(含PyCharm的使用教程)》:本文主要介绍Python虚拟环境终极(含PyCharm的使用教程),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录一、为什么需要虚拟环境?二、虚拟环境创建方式对比三、命令行创建虚拟环境(venv)3.1 基础命令3

Python Transformer 库安装配置及使用方法

《PythonTransformer库安装配置及使用方法》HuggingFaceTransformers是自然语言处理(NLP)领域最流行的开源库之一,支持基于Transformer架构的预训练模... 目录python 中的 Transformer 库及使用方法一、库的概述二、安装与配置三、基础使用:Pi

关于pandas的read_csv方法使用解读

《关于pandas的read_csv方法使用解读》:本文主要介绍关于pandas的read_csv方法使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录pandas的read_csv方法解读read_csv中的参数基本参数通用解析参数空值处理相关参数时间处理相关

使用Node.js制作图片上传服务的详细教程

《使用Node.js制作图片上传服务的详细教程》在现代Web应用开发中,图片上传是一项常见且重要的功能,借助Node.js强大的生态系统,我们可以轻松搭建高效的图片上传服务,本文将深入探讨如何使用No... 目录准备工作搭建 Express 服务器配置 multer 进行图片上传处理图片上传请求完整代码示例

SpringBoot条件注解核心作用与使用场景详解

《SpringBoot条件注解核心作用与使用场景详解》SpringBoot的条件注解为开发者提供了强大的动态配置能力,理解其原理和适用场景是构建灵活、可扩展应用的关键,本文将系统梳理所有常用的条件注... 目录引言一、条件注解的核心机制二、SpringBoot内置条件注解详解1、@ConditionalOn

Python中使用正则表达式精准匹配IP地址的案例

《Python中使用正则表达式精准匹配IP地址的案例》Python的正则表达式(re模块)是完成这个任务的利器,但你知道怎么写才能准确匹配各种合法的IP地址吗,今天我们就来详细探讨这个问题,感兴趣的朋... 目录为什么需要IP正则表达式?IP地址的基本结构基础正则表达式写法精确匹配0-255的数字验证IP地

使用Python实现全能手机虚拟键盘的示例代码

《使用Python实现全能手机虚拟键盘的示例代码》在数字化办公时代,你是否遇到过这样的场景:会议室投影电脑突然键盘失灵、躺在沙发上想远程控制书房电脑、或者需要给长辈远程协助操作?今天我要分享的Pyth... 目录一、项目概述:不止于键盘的远程控制方案1.1 创新价值1.2 技术栈全景二、需求实现步骤一、需求

Spring LDAP目录服务的使用示例

《SpringLDAP目录服务的使用示例》本文主要介绍了SpringLDAP目录服务的使用示例... 目录引言一、Spring LDAP基础二、LdapTemplate详解三、LDAP对象映射四、基本LDAP操作4.1 查询操作4.2 添加操作4.3 修改操作4.4 删除操作五、认证与授权六、高级特性与最佳

SpringQuartz定时任务核心组件JobDetail与Trigger配置

《SpringQuartz定时任务核心组件JobDetail与Trigger配置》Spring框架与Quartz调度器的集成提供了强大而灵活的定时任务解决方案,本文主要介绍了SpringQuartz定... 目录引言一、Spring Quartz基础架构1.1 核心组件概述1.2 Spring集成优势二、J

Android Studio 配置国内镜像源的实现步骤

《AndroidStudio配置国内镜像源的实现步骤》本文主要介绍了AndroidStudio配置国内镜像源的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、修改 hosts,解决 SDK 下载失败的问题二、修改 gradle 地址,解决 gradle