element-ui表格跨页选择数据

element-ui表格跨页选择

    • 1.template部分
    • 2.js部分
    • 3.全部代码

1.template部分

  • 为table组件添加ref=‘table’
  • 绑定数据源 :data=‘list’
  • 添加select和select-all事件(事件处理函数为handleSelect)
<template><div><el-table ref='table' :data="list" max-height="600"@select="handleSelect" @select-all='handleSelect'><el-table-column fixed="left" type="selection" width="55" align="center" /><el-table-column label="商品名称" align="center" prop="name" min-width="200" /><el-table-column label="商品条码" align="center" prop="id" min-width="180" /><el-table-column label="商品单位" align="center" prop="unit" min-width="180" /></el-table></div>
</template>

2.js部分

  • 在data函数中定义全局选中数据的变量allIds
  • 在data函数中定义数据源的变量list
<script>export default {data() {return {allIds: [],//当前选中数据的id数组list: [], //表格数据源}}}
</script>
  • 请求列表数据,并根据allIds判断当前列表中是否有选中的数据,如果有则默认选中
<script>export default {data() {return {allIds: [],//当前选中的数据list: [], //表格数据源}},created() {this.getList()},methods: {getList() {axios.get('xxxxx').then(res => { //模拟数据请求this.list = response.data.rows; //数据源//循环数据列表,判断当前数据的id是否存在于allIds中,如果存在则默认选中this.$nextTick(() => {this.list.map((item) => {if(this.allIds.includes(item.id)) {this.$refs.table.toggleRowSelection(item,true)}})})})}}}
</script>
  • handleSelect事件函数的实现
    监听单选、全选事件
    判断allIds数据里面是否包含当前分页的数据,如果包含,则将当前页面数据的id从allIds 里删除
    然后将当前页选中的数据重新push到allIds数组里
<script>export default {methods: {// 跨页选择handleSelect(selection) {let allIds = [...this.allIds];let delIds = this.list.map(item => item.id);for(let i = 0; i < this.allIds.length; i++) {let id = allIds[i];if(delIds.includes(id)) {allIds.splice(i,1);i--;}}selection.map(item => {if(!allIds.includes(item.id)) {allIds.push(item.id)}})this.allIds = [...allIds]}}}
</script>

3.全部代码

<template><div><el-table ref='table' :data="list" max-height="600"@select="handleSelect" @select-all='handleSelect'><el-table-column fixed="left" type="selection" width="55" align="center" /><el-table-column label="商品名称" align="center" prop="name" min-width="200" /><el-table-column label="商品条码" align="center" prop="id" min-width="180" /><el-table-column label="商品单位" align="center" prop="unit" min-width="180" /></el-table></div>
</template><script>export default {data() {return {allIds: [],//当前选中的数据list: [], //表格数据源}},created() {this.getList()},methods: {getList() {axios.get('xxxxx').then(res => { //模拟数据请求this.list = response.data.rows; //数据源//循环数据列表,判断当前数据的id是否存在于allIds中,如果存在则默认选中this.$nextTick(() => {this.list.map((item) => {if(this.allIds.includes(item.id)) {this.$refs.table.toggleRowSelection(item,true)}})})})},// 跨页选择handleSelect(selection) {let allIds = [...this.allIds];let delIds = this.list.map(item => item.id);for(let i = 0; i < this.allIds.length; i++) {let id = allIds[i];if(delIds.includes(id)) {allIds.splice(i,1);i--;}}selection.map(item => {if(!allIds.includes(item.id)) {allIds.push(item.id)}})this.allIds = [...allIds]}}}
</script>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/23768.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

qmt量化交易策略小白学习笔记第17期【qmt编程之获取对应周期的北向南向数据--方式1:内置python】

qmt编程之获取对应周期的北向南向数据 qmt更加详细的教程方法&#xff0c;会持续慢慢梳理。 也可找寻博主的历史文章&#xff0c;搜索关键词查看解决方案 &#xff01; 感谢关注&#xff0c;咨询免费开通量化回测与获取实盘权限&#xff0c;欢迎和博主联系&#xff01; 获取…

java+SimpleRegression 线性模型,针对采集到的大数据设备温度,对设备温度做出预测

首先,让我们通过以下表格展示预测模型开发 Java 的整体流程: 步骤 描述 1 数据收集与清洗 2 特征工程处理 3 模型选择与训练 4 模型评估与调优 5 模型应用与部署 然后引入java的类库 org.apache.commons.math3 math使用原则 math3可谓是轻量级自容器…

小程序开发平台版源码系统——社区论坛小程序功能 带完整的安装代码包以及搭建教程

系统概述 这款社区论坛小程序源码系统是一款功能强大、易于使用的开发平台版源码系统。它采用先进的技术架构&#xff0c;结合了丰富的功能模块&#xff0c;能够满足不同用户的需求。该系统具有高度的可扩展性和灵活性&#xff0c;能够根据用户的需求进行定制化开发&#xff0…

【ffmpeg】本地格式转换 mp4转wav||裁剪mp4

个人感受&#xff1a;太爽了&#xff01;&#xff01;&#xff01;&#xff08;可能用惯了转换网站和无良的转换软件&#xff09; ———— 使用FFmpeg把mp4文件转换为WAV文件 - 简书 (jianshu.com) FFMPEG 视频分割和合并 - 简书 (jianshu.com) ———— 示例 ffmpeg -i …

Qwen2开源发布!0.5B到72B,显著提升!

Qwen2是一个开源的自然语言处理模型&#xff0c;它从0.5B到72B参数规模的显著提升&#xff0c;代表着自然语言处理技术的重大进步。Qwen2的发布&#xff0c;意味着我们可以期待模型在各项自然语言处理任务上&#xff0c;如文本生成、文本分类、机器翻译等&#xff0c;都会有更加…

Qt 窗口居中显示

Qt 窗口居中显示 引言一、窗体的setGeometry函数二、计算屏幕中心然后move三、借助QRect计算四、补充知识点 引言 窗口居中可以提供良好的视觉效果、突出重点内容、提升用户导航和操作的便利性&#xff0c;有助于改善用户体验。 Qt一般情况下&#xff0c;其Mainwindow或弹出的…

咖啡机器人如何精准控制液位流量

在如今快节奏的生活中&#xff0c;精确控制液位流量的需求愈发迫切&#xff0c;特别是在咖啡机器人等精密设备中。为了满足这一需求&#xff0c;工程师们不断研发出各种先进的技术&#xff0c;以确保液体流量的精准控制。其中&#xff0c;霍尔式流量计和光电式流量计就是两种常…

【Spring Cloud】Gateway 服务网关核心架构的执行流程和断言

文章目录 基本概念执行流程断言内置路由断言工厂自定义路由断言工厂 总结 基本概念 路由(Route)是gateway中最基本的组件之一&#xff0c;表示一个具体的路由信息载体。主要定义了下面的几个信息&#xff1a; id&#xff1a;路由标识符&#xff0c;区别于其他Route。uri&…

论文合集整理推荐2024.6.4

论文合集整理推荐2024.6.4 原创 小王搬运工 时序课堂 2024-06-04 20:12 四川 ‍2012年论文合集&#xff1a;论文入口 ‍2019年论文合集&#xff1a;论文入口 2021年论文合集&#xff1a;论文入口 2022年论文合集&#xff1a;论文入口 2023年论文合集&#xff1a;论文入口…

carbondata入库数据查询异常排查

1&#xff0c;背景&#xff1a;carbondata的入库segments对应的状态都是success&#xff0c;但是查询的时候报错&#xff0c; 2&#xff0c;排查内容 1&#xff0c;segments的状态 success 2&#xff0c;任务执行记录日志 正常 3&#xff0c;找到对应查询的天&#xff0c;指定对…

8255A-LED

DATA SEGMENTPORTA EQU 280H ;A端口地址PORTB EQU 281H ;B端口地址PORTD EQU 283H ;命令口地址 DATA ENDSCODE SEGMENTASSUME CS:CODE,DS:DATA START:MOV AX, DATAMOV DS, AXMOV DX, PORTDMOV AL, 10010000BOUT DX,ALMOV DX, 281H MOV AL, 00HOUT DX, ALWAIT1:MOV DX, POR…

【JavaEE精炼宝库】多线程(4)深度理解死锁、内存可见性、volatile关键字、wait、notify

目录 一、死锁 1.1 出现死锁的常见场景&#xff1a; 1.2 产生死锁的后果&#xff1a; 1.3 如何避免死锁&#xff1a; 二、内存可见性 2.1 由内存可见性产生的经典案例&#xff1a; 2.2 volatile 关键字&#xff1a; 2.2.1 volatile 用法&#xff1a; 2.2.2 volatile 不…

C/C++ 检测文件是否存在的方法

在C和C中&#xff0c;检测文件是否存在的方法通常涉及到平台特定的API或者使用标准库的功能&#xff08;在C17及以后版本中&#xff09;。以下是几种常见的方法&#xff1a; C 在C中&#xff0c;通常使用POSIX标准&#xff08;在Unix-like系统上&#xff09;或Windows API&am…

PostgreSQL的视图pg_stat_user_tables

PostgreSQL的视图pg_stat_user_tables pg_stat_user_tables 是 PostgreSQL 中的一个系统视图&#xff0c;用于显示用户定义的表的统计信息。这些统计信息包括表的访问情况、修改情况以及很多其他的性能指标。这个视图为数据库管理员提供了丰富的数据&#xff0c;可以帮助他们进…

使用 Scapy 库编写 ICMP 时间戳攻击脚本

一、介绍 ICMP时间戳攻击&#xff08;ICMP Timestamp Attack&#xff09;是一种利用ICMP协议中的Timestamp请求和响应消息来实施的攻击。攻击者发送大量的ICMP Timestamp请求消息到目标主机&#xff0c;以触发目标主机对每个请求进行响应&#xff0c;从而消耗目标系统的网络资…

Codeforces Round 950 (Div. 3)

好久没写题解了&#xff0c;今天来写个题解。 A - 问题 Generator #include "bits/stdc.h" using namespace std;#define int long long #define endl \n #define IOS ios::sync_with_stdio(0),cin.tie(0); #define all(x) x.begin(),x.end() #define pi pair<in…

【Linux】(一)——Linux基础和Linux命令基础语法

目录 Linux基础Linux发行版本Linux终端Linux命令 Linux基础 Linux&#xff0c;通常指的是GNU/Linux操作系统&#xff0c;这是一个开源且免费使用的类UNIX操作系统。它的核心组件——Linux内核&#xff0c;由林纳斯托瓦兹&#xff08;Linus Torvalds&#xff09;在1991年10月5日…

Arthas使用教程——JVM常用命令

JVM相关命令 dashboard——当前系统的实时数据面板 显示当前 tomcat 的实时信息。 使用方式&#xff1a;dashboard 数据说明 ID: Java 级别的线程 ID&#xff0c;注意这个 ID 不能跟 jstack 中的 nativeID 一一对应。 NAME: 线程名 GROUP: 线程组名 PRIORITY: 线程优先级…

Rocky Linux安装与基础配置

目录 背景与起源 主要特点 目标用户 发展前景 下载 安装 常用配置命令&#xff1a; 更换镜像源 Rocky Linux 是一个开源的、由社区驱动的操作系统&#xff0c;旨在使用 Red Hat Enterprise Linux&#xff08;RHEL&#xff09;源码构建的下游二进制兼容发行版。以下是关于…

优思学院|一文看懂新版FMEA与FMEA的七大步骤

FMEA的起源 FMEA最早起源于20世纪40年代的美国军工行业。当时&#xff0c;美国军方为了提高武器系统的可靠性和安全性&#xff0c;开始使用FMEA来识别和评估潜在的故障模式及其影响。1949年&#xff0c;美国军方发布了《军用程序手册》&#xff08;Military Procedures Handbo…