树形表格的使用——配置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

相关文章

使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)

《使用Java解析JSON数据并提取特定字段的实现步骤(以提取mailNo为例)》在现代软件开发中,处理JSON数据是一项非常常见的任务,无论是从API接口获取数据,还是将数据存储为JSON格式,解析... 目录1. 背景介绍1.1 jsON简介1.2 实际案例2. 准备工作2.1 环境搭建2.1.1 添加

C#读取本地网络配置信息全攻略分享

《C#读取本地网络配置信息全攻略分享》在当今数字化时代,网络已深度融入我们生活与工作的方方面面,对于软件开发而言,掌握本地计算机的网络配置信息显得尤为关键,而在C#编程的世界里,我们又该如何巧妙地读取... 目录一、引言二、C# 读取本地网络配置信息的基础准备2.1 引入关键命名空间2.2 理解核心类与方法

如何使用celery进行异步处理和定时任务(django)

《如何使用celery进行异步处理和定时任务(django)》文章介绍了Celery的基本概念、安装方法、如何使用Celery进行异步任务处理以及如何设置定时任务,通过Celery,可以在Web应用中... 目录一、celery的作用二、安装celery三、使用celery 异步执行任务四、使用celery

使用Python绘制蛇年春节祝福艺术图

《使用Python绘制蛇年春节祝福艺术图》:本文主要介绍如何使用Python的Matplotlib库绘制一幅富有创意的“蛇年有福”艺术图,这幅图结合了数字,蛇形,花朵等装饰,需要的可以参考下... 目录1. 绘图的基本概念2. 准备工作3. 实现代码解析3.1 设置绘图画布3.2 绘制数字“2025”3.3

Jsoncpp的安装与使用方式

《Jsoncpp的安装与使用方式》JsonCpp是一个用于解析和生成JSON数据的C++库,它支持解析JSON文件或字符串到C++对象,以及将C++对象序列化回JSON格式,安装JsonCpp可以通过... 目录安装jsoncppJsoncpp的使用Value类构造函数检测保存的数据类型提取数据对json数

python使用watchdog实现文件资源监控

《python使用watchdog实现文件资源监控》watchdog支持跨平台文件资源监控,可以检测指定文件夹下文件及文件夹变动,下面我们来看看Python如何使用watchdog实现文件资源监控吧... python文件监控库watchdogs简介随着Python在各种应用领域中的广泛使用,其生态环境也

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

springboot整合 xxl-job及使用步骤

《springboot整合xxl-job及使用步骤》XXL-JOB是一个分布式任务调度平台,用于解决分布式系统中的任务调度和管理问题,文章详细介绍了XXL-JOB的架构,包括调度中心、执行器和Web... 目录一、xxl-job是什么二、使用步骤1. 下载并运行管理端代码2. 访问管理页面,确认是否启动成功

最新版IDEA配置 Tomcat的详细过程

《最新版IDEA配置Tomcat的详细过程》本文介绍如何在IDEA中配置Tomcat服务器,并创建Web项目,首先检查Tomcat是否安装完成,然后在IDEA中创建Web项目并添加Web结构,接着,... 目录配置tomcat第一步,先给项目添加Web结构查看端口号配置tomcat    先检查自己的to

使用Nginx来共享文件的详细教程

《使用Nginx来共享文件的详细教程》有时我们想共享电脑上的某些文件,一个比较方便的做法是,开一个HTTP服务,指向文件所在的目录,这次我们用nginx来实现这个需求,本文将通过代码示例一步步教你使用... 在本教程中,我们将向您展示如何使用开源 Web 服务器 Nginx 设置文件共享服务器步骤 0 —