element plus el-table多选框跨页多选保留

一、基础多选配置

通过 type="selection" 开启多选列,并绑定 selection-change 事件获取选中数据

html 复制代码
<template>
  <el-table 
    :data="tableData" 
    @selection-change="handleSelectionChange"
  >
    <el-table-column type="selection" width="55" />
    <el-table-column prop="name" label="名称" />
    <!-- 其他列 -->
  </el-table>
</template>

<script setup>
const tableData = ref([...]);
const selectedData = ref([]);

const handleSelectionChange = (val) => {
  selectedData.value = val; // 获取选中数据
};
</script>

二、跨页多选保留

需设置 row-key 和 reserve-selection 属性实现跨页保留选中状态

html 复制代码
<el-table 
  :data="tableData" 
  row-key="id" 
  @selection-change="handleSelectionChange"
>
  <el-table-column 
    type="selection" 
    :reserve-selection="true" 
    width="55" 
  />
  <!-- 其他列 -->
</el-table>

三、条件控制可选状态

通过 selectable 属性动态控制行是否可选中

html 复制代码
<el-table-column 
  type="selection" 
  :selectable="(row, index) => row.status !== 'disabled'"
/>

四、手动回显选中数据

使用 toggleRowSelection 方法回显已选数据

html 复制代码
<el-table ref="tableRef" row-key="id">
  <!-- 列配置 -->
</el-table>

<script setup>
import { nextTick } from 'vue';

const defaultSelected = ref([...]); // 默认选中数据

// 回显方法
const initSelection = async () => {
  await nextTick();
  defaultSelected.value.forEach(row => {
    tableRef.value.toggleRowSelection(row, true);
  });
};
</script>

五、样式与交互优化

‌行点击触发多选‌:通过 @row-click 配合 toggleRowSelection 实现点击行选中

html 复制代码
<el-table @row-click="handleRowClick">
  <!-- 列配置 -->
</el-table>

<script setup>
const handleRowClick = (row) => {
  tableRef.value.toggleRowSelection(row);
};
</script>

‌调整多选框样式‌:通过自定义 CSS 覆盖默认样式(如间距、颜色等)。

六、注意事项:

id必须是表格数据中存在的key,请根据自己的表格数据结构来定义。

性能优化:跨页多选需结合分页接口动态加载数据,避免一次性加载全量数据。

完整示例可参考 Element Plus 官方文档或上述实现逻辑组合使用

相关推荐
山河木马9 小时前
矩阵专题3-怎么创建投影矩阵(uProjectionMatrix)
javascript·webgl·计算机图形学
泯泷10 小时前
第 2 篇:设计第一套字节码:Opcode、Instruction 与 Constant Pool
前端·javascript·安全
泯泷10 小时前
第 1 篇:从 1 + 2 开始:亲手写出第一台 JSVM
前端·javascript·安全
古夕11 小时前
第三方 SSO 接入实践:redirect_uri 编码、回调一致性与跨项目联调
前端·vue.js
朦胧之11 小时前
页面白屏卡住排查方法
前端·javascript
Ruihong11 小时前
Vue withDefaults 转 React:VuReact 怎么处理?
vue.js·react.js·面试
犇驫聊AI12 小时前
Chrome DevTools MCP + Claude Code 自定义skills生成接口代码生成器
前端·javascript
kyriewen12 小时前
别再这样写 async/await 了:我在 Code Review 中见过最多的 8 个错误
前端·javascript·面试
稀土熊猫君13 小时前
一个人能做出什么开源项目?
vue.js·后端·开源
用户2986985301417 小时前
在 React 中使用 JavaScript 将 Excel 转换为 SVG
前端·javascript·react.js