树形表格的使用——配置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数据验证神器Pydantic库的使用和实践中的避坑指南

《Python数据验证神器Pydantic库的使用和实践中的避坑指南》Pydantic是一个用于数据验证和设置的库,可以显著简化API接口开发,文章通过一个实际案例,展示了Pydantic如何在生产环... 目录1️⃣ 崩溃时刻:当你的API接口又双叒崩了!2️⃣ 神兵天降:3行代码解决验证难题3️⃣ 深度

Linux内核定时器使用及说明

《Linux内核定时器使用及说明》文章详细介绍了Linux内核定时器的特性、核心数据结构、时间相关转换函数以及操作API,通过示例展示了如何编写和使用定时器,包括按键消抖的应用... 目录1.linux内核定时器特征2.Linux内核定时器核心数据结构3.Linux内核时间相关转换函数4.Linux内核定时

python中的flask_sqlalchemy的使用及示例详解

《python中的flask_sqlalchemy的使用及示例详解》文章主要介绍了在使用SQLAlchemy创建模型实例时,通过元类动态创建实例的方式,并说明了如何在实例化时执行__init__方法,... 目录@orm.reconstructorSQLAlchemy的回滚关联其他模型数据库基本操作将数据添

Spring配置扩展之JavaConfig的使用小结

《Spring配置扩展之JavaConfig的使用小结》JavaConfig是Spring框架中基于纯Java代码的配置方式,用于替代传统的XML配置,通过注解(如@Bean)定义Spring容器的组... 目录JavaConfig 的概念什么是JavaConfig?为什么使用 JavaConfig?Jav

Spring Boot Interceptor的原理、配置、顺序控制及与Filter的关键区别对比分析

《SpringBootInterceptor的原理、配置、顺序控制及与Filter的关键区别对比分析》本文主要介绍了SpringBoot中的拦截器(Interceptor)及其与过滤器(Filt... 目录前言一、核心功能二、拦截器的实现2.1 定义自定义拦截器2.2 注册拦截器三、多拦截器的执行顺序四、过

MySQL快速复制一张表的四种核心方法(包括表结构和数据)

《MySQL快速复制一张表的四种核心方法(包括表结构和数据)》本文详细介绍了四种复制MySQL表(结构+数据)的方法,并对每种方法进行了对比分析,适用于不同场景和数据量的复制需求,特别是针对超大表(1... 目录一、mysql 复制表(结构+数据)的 4 种核心方法(面试结构化回答)方法 1:CREATE

Java使用Spire.Doc for Java实现Word自动化插入图片

《Java使用Spire.DocforJava实现Word自动化插入图片》在日常工作中,Word文档是不可或缺的工具,而图片作为信息传达的重要载体,其在文档中的插入与布局显得尤为关键,下面我们就来... 目录1. Spire.Doc for Java库介绍与安装2. 使用特定的环绕方式插入图片3. 在指定位

Springboot3 ResponseEntity 完全使用案例

《Springboot3ResponseEntity完全使用案例》ResponseEntity是SpringBoot中控制HTTP响应的核心工具——它能让你精准定义响应状态码、响应头、响应体,相比... 目录Spring Boot 3 ResponseEntity 完全使用教程前置准备1. 项目基础依赖(M

springboot的controller中如何获取applicatim.yml的配置值

《springboot的controller中如何获取applicatim.yml的配置值》本文介绍了在SpringBoot的Controller中获取application.yml配置值的四种方式,... 目录1. 使用@Value注解(最常用)application.yml 配置Controller 中

springboot中配置logback-spring.xml的方法

《springboot中配置logback-spring.xml的方法》文章介绍了如何在SpringBoot项目中配置logback-spring.xml文件来进行日志管理,包括如何定义日志输出方式、... 目录一、在src/main/resources目录下,也就是在classpath路径下创建logba