el-table 多选表格存在分页,编辑再次操作勾选会丢失原来选中的数据

14 篇文章 1 订阅

el-table表格多选时,只需要添加type="selection"row-key@selection-change,如果存在分页时需要加上reserve-selection,这里就不写具体的实现方法了,可以查看我之前的文章,这篇文章主要说一下存在的问题。

问题:

1.进入列表,勾选表格第1页的一条数据,然后切换进入第2页,再勾选一条数据
在这里插入图片描述

在这里插入图片描述
如上图,每页分别勾选了一条数据,然后保存

2.再点击编辑,进入后,不要点击第二页,直接在第一页上在勾选一条数据,然后保存,你会发现,第二页的数据消失了。如果先点击切换进入第二页,再点击保存就没问题了

疑问:这是什么情况,为什么会这样呢?

因为表格是存在分页,初始化进去的时候,只加载了第一页的数据,后面页面的数据是拿不到的,el-table组件只会存第一页选中的,当你点击一下第二页的时候,@selection-change的参数就正常了

如果解决

那肯定是有方法解决的,使用toggleRowSelection方法把数据硬塞进去

this.$nextTick(() => {
  // this.multipleSelection:第一页和第二页选中的数据数组, this.tableList是表格数据
   if (this.multipleSelection.length) {
       // this.$refs.elTable 当前表格ref
       this.$refs.elTable.clearSelection()

       this.multipleSelection.forEach(row => {
           const selectedRow = this.tableList.find(item => item.id === row.id)
           if(selectedRow){
               // 当前页(第一页)需要被选中的数据使其选中
               this.$refs.elTable.toggleRowSelection(selectedRow, true);
           }else{
               // 不在当前页(第二页)的数据,也硬塞到@selection-change的参数中,这时当你在第一页选中其他数据时,selection-change的参数也会带着第二页的数据
               this.$refs.elTable.toggleRowSelection(row, true);
           }
       })
   }
})
第二种方法:

针对这种有分页的还有一种方法,就是再请求一个接口获取所有数据(如后端没提供,页码数量可填大点),然后在总的数据中查找之前选中的数据。
allTableList是所有数据, ids是选中的id数据

初始化进入的时候,先请求表格总的数据,再获取表格分页数据

mounted(){
	init()
},
async init(){
	await setCheck()
	await getTableList()
},
// 这里是请求接口获取表格分页数据
getTableList(){
	// this.tableList = 
},
// 这里获取所有的数据
getAllTableList(){
	// 请求获取所有的数据,然后return出去
	// return allList
},
// 设置选中
async setCheck() {
	const allTableList = await getAllTableList()
	allTableList.forEach((item) => {
		if(ids.has(item.id)){
			this.$refs.elTable.toggleRowSelection(item, true)
		}
	})
}
  • 11
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个使用 Element UI 的 el-table 多选表格,并且支持数据回显的完整代码示例: ```html <template> <div> <el-table :data="tableData" :row-key="row => row.id" style="width: 100%"> <el-table-column type="selection" width="55"> </el-table-column> <el-table-column prop="name" label="姓名"> </el-table-column> <el-table-column prop="age" label="年龄"> </el-table-column> </el-table> <el-button @click="handleSelectionChange">保存</el-button> </div> </template> <script> export default { data() { return { tableData: [ { id: 1, name: '张三', age: 18, selected: false }, { id: 2, name: '李四', age: 22, selected: false }, { id: 3, name: '王五', age: 25, selected: false } ] } }, methods: { handleSelectionChange(selection) { this.tableData.forEach(row => { if (selection.indexOf(row) >= 0) { row.selected = true } else { row.selected = false } }) console.log('选中的行:', selection) console.log('选中数据:', this.tableData.filter(row => row.selected)) } } } </script> ``` 在这个示例中,我们使用了 Element UI 的 el-table 组件来实现多选表格的功能。通过设置 `type="selection"`,我们可以让 el-table-column 组件变成一个多选框列。同时,我们使用 `selection` 属性来绑定选中的行,这样就可以获取到用户选择的数据了。 为了支持数据回显,我们在表格数据中添加了一个 `selected` 字段来标记行是否被选中。在 `handleSelectionChange` 方法中,我们遍历选中的行,更新它们在表格数据中对应的 `selected` 字段。这样就可以实现选中数据的回显了。同时,我们也输出了选中的行和数据,方便开发者进行后续的处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值