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

ElementPlus 多个并列 Table 独立全选/取消全选 (适配嵌套表格业务)

业务场景

在后台管理系统开发中,经常会遇到动态渲染多个并列表格的复杂场景。

以某租房后台为例:

一个户型下可以添加多个「房间」,每个房间对应一张独立表格,表格内可配置租期、付款方式、月租金等参数。业务需要实现:

  • 所有表格统一全选取消全选

  • 每个表格支持单独手动勾选,互不干扰

  • 精准记录「哪些表格处于选中状态」,用于后续批量赋值、批量删除

  • 表格无表头、嵌套表单组件,贴合后台复杂配置页样式

今天分享一套零 Bug、完全贴合真实业务的多表格全选解决方案(Vue3 + TS + ElementPlus)。

原理分析

1、v-for循环绑定同名ref,通过下标multipleTable.value[i]可获取每一个表格实例,解决 ref 覆盖问题

2、Vue 是异步 DOM 更新,nextTick保证在 DOM 渲染完成后再操作表格勾选 ,是功能生效的关键

3、ElementPlus 核心表格 API

  • toggleAllSelection():表格原生全选/反选方法

  • clearSelection():清空表格所有选中项

  • selection-change:表格勾选状态变化监听事件

核心完整源码

<template> <div class="demo"> <!-- 全局操作按钮 --> <el-button type="primary" link @click="selectAll">[全选]</el-button> <el-button type="primary" link @click="selectCancel">[取消全选]</el-button> <!-- 动态循环多个独立表格 --> <el-table v-for="(room, roomIndex) in formData.rooms" :key="roomIndex" :data="room.prices" border :show-header="false" ref="multipleTable" @selection-change="(val) => handleSelectChange(val, roomIndex)" highlight-current-row > <!-- 多选框列 --> <el-table-column type="selection" width="55"></el-table-column> <!-- 房间号(整表共用) --> <el-table-column label="房间号" width="150"> <template #default="{row}"> <el-input v-model="room.name" placeholder="房间号" clearable/> </template> </el-table-column> <!-- 租期 --> <el-table-column label="租期" width="150"> <template #default="{row}"> <el-select v-model="row.term_id" placeholder="租期" clearable filterable> <el-option label="半年" :value="1" /> <el-option label="一年" :value="2" /> </el-select> </template> </el-table-column> <!-- 付款方式 --> <el-table-column label="付款方式" width="150"> <template #default="{row}"> <el-select v-model="row.pay_type" placeholder="付款方式" clearable filterable> <el-option label="月付" :value="1" /> <el-option label="季付" :value="2" /> </el-select> </template> </el-table-column> <!-- 月租金 --> <el-table-column label="月租金" width="220"> <template #default="{row}"> <el-input v-model="row.price" placeholder="月租金" clearable> <template #append>元/月</template> </el-input> </template> </el-table-column> <!-- 默认开关 --> <el-table-column label="默认" > <template #default="{row, $index}"> <el-switch v-model="row.is_default" active-text="默认" inline-prompt :width="50" :active-value="1" :inactive-value="0" /> </template> </el-table-column> </el-table> </div> </template> <script lang="ts" setup> import { ref, reactive, nextTick } from 'vue' import type { ElTable } from 'element-plus' // 模拟业务数据源:多个房间 = 多个表格 const formData = reactive({ rooms: [ { name: 'a', prices: [{ term_id: '', pay_type: '', price: '', is_default: 0 }] }, { name: 'b', prices: [{ term_id: '', pay_type: '', price: '', is_default: 0 }] } ] }) // 收集所有表格实例(核心:解决多表格ref覆盖问题) const multipleTable = ref<(ElTable | null)[]>([]) // 记录【被选中的表格下标】,用于后续批量操作 const selectData = ref<number[]>([]) // 全局全选:所有表格全部勾选 const selectAll = () => { nextTick(() => { for (let i = 0; i < formData.rooms.length; i++) { const table = multipleTable.value[i] if (table) { table.toggleAllSelection() } // 记录所有表格为选中状态 if (!selectData.value.includes(i)) { selectData.value.push(i) } } console.log('全选选中索引', selectData.value) }) } // 全局取消全选:清空所有表格勾选 const selectCancel = () => { nextTick(() => { for (let i = 0; i < formData.rooms.length; i++) { const table = multipleTable.value[i] if (table) { table.clearSelection() } } }) // 清空选中记录 selectData.value = [] console.log('取消全选', selectData.value) } // 单表格勾选状态监听:实时维护选中表格索引 const handleSelectChange = (val: any[], roomIndex: number) => { if (val.length) { // 表格有选中行,加入选中列表 if (!selectData.value.includes(roomIndex)) { selectData.value.push(roomIndex) } } else { // 表格无选中行,移出选中列表 selectData.value = selectData.value.filter(item => item !== roomIndex) } console.log('当前选中表格索引', selectData.value) } </script> <style ></style>
http://www.rkmt.cn/news/1407287.html

相关文章:

  • dashscope-openai 20260527
  • 威海多特瑞:9 年深耕流量仪表,以隔离涡街技术打破国外垄断 - 资讯纵览
  • 为AI智能体构建防篡改审计日志:基于数字签名的责任追溯方案
  • 【Java零基础入门22】Java注解完整详解:内置注解、元注解、自定义注解
  • 电站锅炉燃烧优化及低NOx排放控制若干问题优化算法【附仿真】
  • 智能化的固定资产管理软件公司选型参考与选择逻辑 - 资讯快报
  • 2026年罗茨风机深度选型:如何为你的工业场景匹配最佳方案? - 资讯纵览
  • Inspex:一种提升顺序处理器性能的轻量级推测执行微架构
  • FPGA实时癫痫检测:时间序列分割与异常检测的硬件实现
  • API聚合平台从比价到选型:2026年AI大模型API中转站选购核心逻辑与实战评估
  • StreamFX终极指南:5个核心功能让你的直播画面瞬间升级
  • 终极指南:如何在Windows上使用QKeyMapper实现零重启按键映射
  • 义乌网店饰品批发厂家实力对比:五大硬指标逐一解析 - 资讯快报
  • WarcraftHelper完整指南:让魔兽争霸3在现代电脑上完美运行的简单方案
  • 创业公司如何建立合作伙伴生态
  • 广州高精度固晶机厂家推荐哪家好?领衔六大实力企业!
  • 高端腕表维修深度测评|从设备、技术、服务四维实测,解析盛时出圈原因 - 资讯快报
  • 圆刀片定制批发,选口碑好的就错了?
  • 高效搞定学术文稿:paperxie 论文智能创作功能实操用法分享
  • 电商关键词挖掘:Java 爬虫抓取 1688 推荐搜索词
  • 7×24小时不打烊:数字人智能客服如何重塑政务服务“最后一公里“
  • 2026四向穿梭车怎么选?越来越多企业开始关注“系统能力”
  • 2026年河北钢格栅行业深度攻略:选型、合规、品牌与落地全指南 - 资讯纵览
  • Vibe Coding实战:冗长提示词并非核心,工程规则搭建才决定开发上限
  • 【品牌包装全案】面肌时光|白细胞血清蛋白抗老精华液 高端礼盒包装设计
  • 2026年当前济南GEO服务市场格局与头部企业深度解析 - 资讯纵览
  • 上海装修公司综合实力测评 - 资讯纵览
  • 高危预警|CVE-2026-47101 LiteLLM 权限提升漏洞详解与修复方案
  • 从机器学习基础到 MLP(下):神经网络为什么能起作用?
  • Google 官方调整抓取工具 IP 文件路径:SEO 与服务器安全策略要变了?