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

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

代码:

javascript 复制代码
<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>
相关推荐
an3174226 分钟前
解决 VSCode 中 ESLint 格式化不生效问题:新手也能看懂的配置指南
前端·javascript·vue.js
Lee川2 小时前
🚀《JavaScript 灵魂深处:从 V8 引擎的“双轨并行”看执行上下文的演进之路》
javascript·面试
比特鹰3 小时前
手把手带你用Flutter手搓人生K线
前端·javascript·flutter
大雨还洅下3 小时前
前端JS: 数组扁平化
javascript
奔跑路上的Me3 小时前
前端导出 Word/Excel/PDF 文件
前端·javascript
bluceli3 小时前
JavaScript异步编程深度解析:从回调到Async Await的演进之路
前端·javascript
青青家的小灰灰3 小时前
Vue 3 新标准:<script setup> 核心特性、宏命令与避坑指南
前端·vue.js·面试
SuperEugene3 小时前
路由与布局骨架篇:布局系统 | 头部、侧边栏、内容区、面包屑的拆分与复用
前端·javascript·vue.js
代码煮茶3 小时前
前端网络请求实战 | Axios 从入门到封装(拦截器 / 错误处理 / 重试)
javascript
进击的尘埃3 小时前
组合式函数 Composables 的设计模式:如何写出可复用的 Vue3 Hooks
javascript