element-ui 的el-table,多选翻页后,之前选择的数据丢失问题处理

问题描述

在使用Element UI的el-table组件时,开启多选功能后,当切换分页或重新加载数据时,之前选中的数据会丢失。这是由于表格在重新渲染时未保留之前的选择状态。

解决方案

1.手动存储历史

利用一个数组来保存所有选中的数据,而不仅仅是当前页的数据。

html 复制代码
<el-table
  ref="multipleTable"
  :data="tableData"
  @select = "rowSelectChange"
>
  <el-table-column
    type="selection"
    width="55"
  ></el-table-column>
  <!-- 其他列 -->
</el-table>

<script>
const ids = ref([])
const rowSelectChange=(selection: UserVO[], row: UserVO)=>{
  // 判断是否选中,选中ids增加,取消选中ids删除
  if(selection.filter(item=>item.userId == row.userId).length>=1){
    ids.value.push(row.userId)
  }else{
    ids.value = ids.value.filter(item=>item!=row.userId)
  }
}

const initIds=()=>{
    // initSelectUsers 为默认已经选中的ids
  props.initSelectUsers?.forEach(userItem => {
    ids.value.push(userItem)
 });
}
</script>
2.使用row-key和reserve-selection

对于需要跨页保持选中状态的场景,可以给表格设置row-key并启用reserve-selection属性。这需要确保每行数据有唯一标识(如id)。

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

<script>
const ids = ref([])
const handleSelectionChange = (selection: UserVo) => {
  ids.value = selection.map((item) => item.userId);
}
const getRowKeys=(row:UserVO)=>{
  return row.userId;
}
</script>
注意事项
  • 使用reserve-selection时,必须指定row-key且数据中的该字段必须唯一。
  • 跨页选中会占用内存,数据量过大时建议采用服务器端保存选中状态。

总结

以上可以有效解决分页时选中丢失的问题,对于简单场景,使用reserve-selection属性更为便捷,如果需要修改原有历史数据数组保存 数据更方便。

相关推荐
1314lay_100711 分钟前
Element Plus左侧侧边栏按照屏幕宽度来确定显示和隐藏,如果太小的话,侧边栏消失,菜单会变成一个小按钮,点击按钮以模态框弹出
javascript·vue.js·elementui
看客随心15 分钟前
vue + elementPlus大屏项目使用autofit做适配及注意点
前端·javascript·vue.js
网络点点滴30 分钟前
Vue3 全局API转移到应用对象
前端·javascript·vue.js
终端鹿39 分钟前
插槽(slot):默认插槽、具名插槽、作用域插槽实战
前端·javascript·vue.js
SuperEugene1 小时前
前端组件三层架构:页面/业务/基础组件划分,高内聚低耦合|组件化设计基础篇
前端·javascript·vue.js·架构·前端框架·状态模式
独断万古他化3 小时前
Selenium 实战 —— 抽奖系统 UI 自动化测试框架搭建
java·selenium·测试工具·ui·自动化·测试
D_C_tyu3 小时前
Vue3 + Vite 项目实现页面离开时取消所有未完成请求
前端·vue.js
赢乐3 小时前
前端vue表格el-table或a-table合并行的功能实现
elementui·el-table·element-plus·anti-design-vue·a-table·vue前端·表格合并行
慧一居士4 小时前
pinia-plugin-persistedstate 在nuxt4项目中服务端渲染,不能使用window对象原因
前端·vue.js