vue+elementUi中的table实现跨页多选功能

最近在开发工业品超市的后台系统,遇到一个需求,就是实现在一个table表格中多选数据,由于table表格中的数据较多,所以要分页获取,因此现在的需求变为:如果在跨页的table表格中跨页选择数据

在网上查了好多,有些方法真的是无语的,写的乱七八糟的,我整理一下,亲测有效

看效果图:

这样返回到第一页的时候,第一页选中的两条数据还是勾选的状态的。
点击表格底部的完成选择订单按钮,可以拿到选中的三条数据。

1.跨页多选功能实现

table添加row-key属性
javascript 复制代码
<el-table
        :data="orderData"
        v-loading="orderloading"
        v-if="orderVisible"
        border
        :row-key="getRowKey"
        style="width: 100%"
        height="300px"
        @selection-change="handleSelectionChange"
        ref="multipleTable"
      >
 ....
 </el-table>

简单分析一下上面的代码:

data:就是table表格中要展示的数据,格式是一个数组

v-loading:加载表格数据时,为了能够更好的人性化,可以添加这个加载属性,然后在表格数据加载的过程中有个数据加载中的效果

v-if:因为我这个表格是跟dialog弹层一同存在的,为了保证数据在弹窗打开时能够实时渲染,所以我加了这个判断条件

border:给表格添加边框

row-key:这个就是实现跨页选择的关键,后面会讲到用法

style:给表格添加宽度等css样式

height:给表格添加高度,因为如果表格没有数据或者数据较少的时候,为了美观添加高度限制,这样当表格数据过多时,还可以实现固定表头的效果

selection-change:勾选数据时,会触发此函数

ref:类似于html中的Id,就是可以获取唯一dom的参数

上面中的row-key需要绑定一个唯一值,我这边的table中的数据,每一条数据中的id是唯一值,因此getRowKey函数如下:

javascript 复制代码
getRowKey(row) {
  return row.id;
},

2.在type="selection"元素上添加:reserve-selection="true"

重点:这样就可以了,选了数据再分页再返回去基本是没问题的还是选中状态

相关推荐
gplitems1233 分钟前
Consua WordPress Theme — Business Consulting Sites That Convert With Clarity
javascript
雾削木1 小时前
stm32解锁芯片
javascript·stm32·单片机·嵌入式硬件·gitee
2301_768350232 小时前
Vue第二期:组件及组件化和组件的生命周期
前端·javascript·vue.js
小周同学:3 小时前
Vue项目中将界面转换为PDF并导出的实现方案
javascript·vue.js·pdf
华洛3 小时前
公开一个AI产品的商业逻辑与设计方案——AI带来的涂色卡自由
前端·后端·产品
明远湖之鱼3 小时前
opentype.js 使用与文字渲染
前端·svg·字体
90后的晨仔4 小时前
Vue 3 组合式函数(Composables)全面解析:从原理到实战
前端·vue.js
今天头发还在吗4 小时前
【React】TimePicker进阶:解决开始时间可大于结束时间的业务场景与禁止自动排版
javascript·react.js·ant design
今天头发还在吗4 小时前
【React】动态SVG连接线实现:图片与按钮的可视化映射
前端·javascript·react.js·typescript·前端框架
小刘不知道叫啥4 小时前
React 源码揭秘 | suspense 和 unwind流程
前端·javascript·react.js