当前位置: 首页 > news >正文

结合组件库实现table组件树状数据的增删改

如图所示,可以实现树状数据的新增子项,新增平级,删除。主要用到了递归

代码:

<template><el-table :data="tableData" style="width: 100%; margin-bottom: 20px" row-key="id" border default-expand-all><el-table-column prop="date" label="Date" /><el-table-column prop="name" label="Name" /><el-table-column prop="address" label="Address" /><el-table-column label="Operations"><template #default="scope"><el-button size="small" @click="add(scope.row)">新增平级</el-button><el-button size="small" @click="addSon(scope.row)">新增子级</el-button><el-button size="small" type="danger" @click="delItem(scope.row)">删除</el-button></template></el-table-column></el-table>
</template><script lang="ts" setup>
import { ref } from 'vue'const tableData = ref([{id: 1,date: '2016-05-02',name: 'wangxiaohu',address: 'No. 189, Grove St, Los Angeles',},{id: 2,date: '2016-05-04',name: 'wangxiaohu',address: 'No. 189, Grove St, Los Angeles',},{id: 3,date: '2016-05-01',name: 'wangxiaohu',address: 'No. 189, Grove St, Los Angeles',children: [{id: 31,date: '2016-05-01',name: 'wangxiaohu',address: 'No. 189, Grove St, Los Angeles',},{id: 32,date: '2016-05-01',name: 'wangxiaohu',address: 'No. 189, Grove St, Los Angeles',},],},{id: 4,date: '2016-05-03',name: 'wangxiaohu',address: 'No. 189, Grove St, Los Angeles',},
])// 平级新增递归的方法
const addLeaveLoop = (arr: any[], id: number | string) => {for (let i = 0; i < arr.length; i++) {if (arr[i].id === id) {arr.splice(i + 1, 0, { id: +new Date(), date: '2023-11-03', name: '辉辉', address: 'dashjdsakljdl' })} else if (arr[i].children) {arr[i].children = addLeaveLoop(arr[i].children, id)}}return arr
}
// 新增平级
const add = (row: any) => {addLeaveLoop(tableData.value, row.id)
}// 新增一个子节点的方法
const addSonLoop = (arr: any[], id: number | string) => {for (let i = 0; i < arr.length; i++) {if (arr[i].id === id) {// 判断有没有children,有就前面新增,没有就创建if (arr[i].children && arr[i].children.length) {arr[i].children.unshift({ id: +new Date(), date: '2023-11-03', name: '张三', address: 'dashjdsakljdl' })} else {arr[i].children = [{ id: +new Date(), date: '2023-11-03', name: '李四', address: 'dashjdsakljdl' }]}} else if (arr[i].children) {arr[i].children = addSonLoop(arr[i].children, id)}}return arr
}
// 新增子级
const addSon = (row: any) => {addSonLoop(tableData.value, row.id)
}// 删除递归的方法
const delLoop = (arr: any[], id: number | string) => {for (let i = 0; i < arr.length; i++) {if (arr[i].id === id) {arr.splice(i, 1)} else if (arr[i].children) {arr[i].children = delLoop(arr[i].children, id)}}return arr
}
// 删除
const delItem = (row: any) => {delLoop(tableData.value, row.id)
}
</script>

http://www.lryc.cn/news/216243.html

相关文章:

  • Microsoft 365 管理自动化
  • unraid 安装并设置 zerotier 内网穿透安装 unraid 局域网内其他设备
  • 如何调试 Dubbo 协议调用过程
  • C++初阶 类和对象(上)
  • SoftwareTest4 - 咋设计一个好的测试用例
  • 自定义 Spring Boot Starter 组件
  • 功率放大器的种类和作用是什么
  • 分析外贸SEO推广流程?网站谷歌SEO优化方法?
  • 前端工程化需要知道的一些知识
  • 默认路由配置
  • Annotorious入门教程:图片注释工具
  • 一台服务器是否能够安装多个SSL证书?
  • 如何使用UDP打洞进行内网穿透
  • 如何滴水不漏的学完C语言?
  • 数据库深入浅出,数据库介绍,SQL介绍,DDL、DML、DQL、TCL介绍
  • 拓世大模型 | 立足行业所需,发力终端,缔造智能无限可能
  • NEFU数字图像处理(3)图像分割
  • 图论问题建模和floodfill算法
  • MySQL - 库的操作
  • 多次kerberos认证服务超时
  • Vuex源码-各原理简单总结
  • vcpkg 使用 cmake 编译C/C++工程代码时指定使用静态库链接编译
  • FlinkCDC系列:数据同步对部分字段的处理,只更新部分字段
  • Linux 包操作 (rpm)
  • Docker中OceanBase挂载过后,删除再启动无限重启的解决办法
  • react中的forwardRef 和memo的区别?
  • 偶数矩阵判断【C语言作业】
  • stable-diffusion 电商领域prompt测评集合
  • 协方差矩阵
  • 0基础学习VR全景平台篇第117篇:利用插件地拍补地 - PS教程