使用el-table的案例小结——包含跨页多选、双击行、分页器、编辑\删除行、动态根据分页生成序号

首先看一下业务需求

在这里插入图片描述
需要实现跨页多选,双击行的时候弹出编辑对话框,对每行可以进行编辑和删除,实现分页器。
如果还没在项目中配置element-plus的可以参考文章 从零开始创建vue3项目——包含项目初始化、element-plus、eslint、axios、router、pinia、echarts,也可以参考element-plus官方文档 element-plus

搭建基本的el-table结构

我将一一解释代码,大家后续可以对照代码和文章进行理解观看

<el-table:data="dataList"style="width: 100%"borderrow-key="id"@selection-change="handleSelectionChange"v-loading="loading"@row-dblclick="onClickEditUser"><el-table-column type="selection" width="55" reserve-selection /><el-table-columntype="index":index="indexMethod"label="序号"width="100"/><el-table-column prop="userIdNumber" label="身份证号" /><el-table-column prop="userName" label="姓名" /><el-table-column prop="userBirthday" label="生日" /><el-table-column label="操作" min-width="90"><template #default="{ row }"><el-button @click="onClickEditUser(row)"> 编辑 </el-button><el-button type="danger" @click="onCLickDeleteUser(row)">删除</el-button></template></el-table-column><template #empty><el-empty description="暂无数据"></el-empty></template></el-table>

el-table

  1. el-table 使用 :data="dataList" 绑定数据列表,这个数据就是自己定义的了
  2. border就在表格内添加边框,更加美观
  3. row-key="id"如果要实现跨页多选,这个非常重要,具体的作用是因为后续要给选择框的列添加reserve-selection属性,设置该属性的前提就是el-table设置row-key
    在这里插入图片描述
  4. @selection-change="handleSelectionChange"这个的作用是因为实现了跨页多选,当选择的行发生变化时,就会自动触发这个函数
    ···js
    //多选用户时,存储当前选择的用户
    const multipleSelection = ref([])
    const handleSelectionChange = (val) => {
    multipleSelection.value = val
    }
    ···
  5. v-loading="loading"这个就是当loading为true时,表格中有转圈圈的提示,让交互更加友好,具体为可以设置请求数据时设置loading。
//获取数据
const getUserList = async function () {loading.value = true//接口根据自己实际的写await ...loading.value = false
}
  1. @row-dblclick="onClickEditUser"就是实现双击行时触发响应自定义函数
//编辑用户信息
const onClickEditUser = function (row) {//自定义执行逻辑,row就是当前行的数据userFormDialogRef.value.onClickOpenEditDialog(row)
}

el-table-column

el-table-column就是el-table中每列的数据

  1. <el-table-column type="selection" width="55" reserve-selection />
    这个就是第一列的选择框的列,设置type为selection,要实现跨页多选,就一定设置reserve-selection
    在这里插入图片描述
  2. <el-table-column type="index" :index="indexMethod" label="序号" width="100"/>
    这个就是第二列的序号,设置type为index即可,但是如果仅仅这样设置有个问题,那就是当页面改变时,index仅为当前页的序号。
    举例:当前第一页,index为1-10,切换页面至第二页时,期望Index为11-20,但是此时会还是1-10
    因此需要下述的函数来进行额外处理
//更改序号
//pageNum和pageSize都是自定义的,后面分页器会讲到
const indexMethod = function (index) {return (pageNum.value - 1) * pageSize.value + index + 1
}
  1. 数据列
<el-table-column prop="userIdNumber" label="身份证号" />
<el-table-column prop="userName" label="姓名" />
<el-table-column prop="userBirthday" label="生日" />

这几个就都一样的,label为当前行的名字,prop为绑定的数据,比如姓名绑定的是userName,那么el-table 绑定的dataList的基本结构就是

const dataList = ref([{userIdNumber:'123',userName:'jack',userBirthdat:'2021-01-01'
},{userIdNumber:'123',userName:'jack',userBirthdat:'2021-01-01'
}])
  1. 操作列
<el-table-column label="操作" min-width="90"><template #default="{ row }"><el-button @click="onClickEditUser(row)"> 编辑 </el-button><el-button type="danger" @click="onCLickDeleteUser(row)">删除</el-button></template></el-table-column>

这里使用了template具名插槽,记住一定要设置#default="{row}",这样后续点击编辑删除的时候,才可以传递本行的数据给对应的处理函数
两个el-button分别绑定处理函数,较为简单

使用el-pagination分页器

官方文档

  1. :background="true"这个就是设置分页器的背景,更加美观

  2. layout="jumper,total, prev, pager, next"这个就是设置分页器有哪些元素,分别是页面跳转、总数据数、向前翻页、显示页数、向后翻页,layout中写的数据就是实际显示的数据。实际上还有个size,可以设置每页的数据条数
    在这里插入图片描述

  3. @current-change="onCurrentChange"监听页面变化,触发对应自定义函数

//页数变化时
const onCurrentChange = function (page) {pageNum.value = pagegetUserList()
}
  1. 数据绑定
:total="total"
:page-size="pageSize"
:current-page="pageNum"

这三个分别绑定数据总数,每页数据数目、当前页数

//分页器相关
const total = ref(0)
const pageNum = ref(1)
const pageSize = ref(10)

一般来讲,total是请求数据时,后端一起发送的,pageSize可以固定写死,也可以通过刚才提到的layout的size属性进行动态设置

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

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

相关文章

vue import from

vue import from 导入文件&#xff0c;从XXXX路径&#xff1b;引入文件 import xxxx from “./minins/resize” import xxxx from “./minins/resize.js” vue.config.js 定义 : resolve(src)&#xff1b;就是指src 目录 import xxxx from “/utils/auth” im…

【C++初阶】string类

【C初阶】string类 &#x1f955;个人主页&#xff1a;开敲&#x1f349; &#x1f525;所属专栏&#xff1a;C&#x1f96d; &#x1f33c;文章目录&#x1f33c; 1. 为什么学习string类&#xff1f; 1.1 C语言中的字符串 1.2 实际中 2. 标准库中的string类 2.1 string类 2.…

Web响应式设计———1、Grid布局

1、网格布局 Grid布局 流动网格布局是响应式设计的基础。它通过使用百分比而不是固定像素来定义网格和元素的宽度。这样&#xff0c;页面上的元素可以根据屏幕宽度自动调整大小&#xff0c;适应不同设备和分辨率。 <!DOCTYPE html> <html lang"en"> &l…

Mysql-索引视图

目录 1.视图 1.1什么是视图 1.2为什么需要视图 1.3视图的作用和优点 1.4创建视图 1.5更新视图 1.6视图使用规则 1.7修改视图 1.8删除视图 2.索引 2.1什么是索引 2.2索引特点 2.3索引分类 2.4索引优缺点 2.5创建索引 2.6查看索引 2.7删除索引 1.视图 1.1什么是…

go中map

文章目录 Map简介哈希表与Map的概念Go语言内建的Map类型Map的声明Map的初始化Map的访问Map的添加和修改Map的删除Map的遍历 Map的基本使用Map的声明与初始化Map的访问与操作Map的删除Map的遍历Map的并发问题实现线程安全的Map 3. Map的访问与操作3.1 访问Map元素代码示例&#…

释疑 803-(1)概述 精炼提纯版

目录 习题 1-01计算机网络可以向用户提供哪些服务? 1-02 试简述分组交换的要点。 1-03 试从多个方面比较电路交换、报文交换和分组交换的主要优缺点。 1-05 互联网基础结构的发展大致分为哪几个阶段?请指出这几个阶段最主要的特点。 1-06 简述互联网标准制定的几个阶段…

web网站组成

web网站由四部分组成&#xff1a;浏览器 前端服务器 后端服务器 数据库服务器 流程&#xff1a; 1.浏览器输入网站后&#xff0c;向前端服务器发送请求&#xff0c;前端服务器响应&#xff0c;静态的数据给浏览器。 2.前端代码中script中有url,这个是向后台发送请求的网…

手撕数据结构---------顺序表和链表

1.线性表 线性表&#xff08;linear list&#xff09;是n个具有相同特性的数据元素的有限序列。 线性表是⼀种在实际中⼴泛使 ⽤的数据结构&#xff0c;常⻅的线性表&#xff1a;顺序表、链表、栈、队列、字符串… 线性表在逻辑上是线性结构&#xff0c;也就说是连续的⼀条直…

Python研究生毕业设计,数据挖掘、情感分析、机器学习

最近在学校毕业了&#xff0c;其中有很多毕业论文使用到的代码&#xff0c;如数据挖掘、情感分析、机器学习、数据预测处理、划分数据集和测试集&#xff0c;绘制分类任务&#xff0c;词汇表示&#xff1a;使用TF-IDF向量化器&#xff0c;线性回归、多元线性回归、SVR回归模型&…

ecshop网站部署

目录 步骤1 ecshop网站的部署 一、安装环境 二、设置开机启动 ​三、 测试php ​四、上传安装包 五、安装ecshop 步骤1 ecshop网站的部署 一、安装环境 yum install -y httpd mariadb-server php php-devel php-mysql 浏览器访问&#xff1a;192.168.30.2 二、设置开机启…

LeetCode 415.字符串相加 C++写法

LeetCode 415.字符串相加 C写法 思路&#x1f914;&#xff1a; 首先不能用stoi和tostring来做&#xff0c;如果给一个很大的数那一定存不下。我们可以从后往前一位一位的取&#xff0c;创建一个变量存储进位用于计算下一位数&#xff0c;之后取模得到当前数字&#xff0c;每一…

k8s部署rabbitmq集群

1 部署集群 1.1 安装 # 创建一个中间件的命名空间 kubectl create namespace middleware # 创建ConfigMap,包含RabbitMQ的配置文件内容 kubectl apply -f rabbitmq-configmap.yaml # 配置用于存储RabbitMQ数据的PersistentVolume&#xff08;PV&#xff09;和PersistentVolum…

iPhone 17系列取消17 Plus版本?新一代苹果手机迎来新变革

随着科技的飞速发展&#xff0c;苹果公司再次准备刷新我们的期待&#xff0c;即将推出的iPhone 17系列携带着一系列令人兴奋的升级。今年&#xff0c;苹果打破了常规&#xff0c;将四款新机型带入市场——iPhone 17、17 Pro、17 Pro Max&#xff0c;以及一款全新的成员&#xf…

Java开发之反射与动态代理

#来自ゾフィー&#xff08;佐菲&#xff09; 1 反射&#xff08;Reflect&#xff09; 运行期间&#xff0c;获取类的信息&#xff0c;进行一些操作。 运行时构造类的对象。运行时获取类的成员变量和方法。运行时调用对象的方法&#xff08;属性&#xff09;。 2 Class 类 Cla…

IntelliJ IDEA 2024.1.4最新实用教程!!爽到飞起!!

IntelliJ IDEA 2024.1.4最新破解教程&#xff01;&#xff01;直接2099&#xff01;&#xff01;爽到飞起&#xff01;&#xff01;【资源在末尾】安装馆长为各位看官准备了多个版本&#xff0c;看官可根据自己的需求进行下载和选择安装。https://mp.weixin.qq.com/s/oBgoHdFU4…

视图,存储过程和触发器

目录 视图 创建视图&#xff1a; 视图的使用 查看库中所有的视图 删除视图 视图的作用&#xff1a; 存储过程&#xff1a; 为什么使用存储过程&#xff1f; 什么是存储过程&#xff1f; 存储过程的创建 创建一个最简单的存储过程 使用存储过程 删除存储过程 带参的存储…

前端面试宝典【Javascript篇】【1】

欢迎来到《前端面试宝典》&#xff0c;这里是你通往互联网大厂的专属通道&#xff0c;专为渴望在前端领域大放异彩的你量身定制。通过本专栏的学习&#xff0c;无论是一线大厂还是初创企业的面试&#xff0c;都能自信满满地展现你的实力。 核心特色&#xff1a; 独家实战案例…

VMare centos 7 设置固定ip

第一步获取网关 查看虚拟机的网关-》编辑-》虚拟网络编辑器 NAT模式-》NAT设置 获取网关IP 192.168.70.2 第二步获取主机dns1 在本地主机获取dns1&#xff0c;本地主机调出cmd输入ipconfig dns1为192.168.31.1 用管理员权限的账号进入需要设置固定ip的虚拟机&#xff0c;在t…

使用AOP优化Spring Boot Controller参数:自动填充常用字段的技巧

欢迎来到我的博客&#xff0c;代码的世界里&#xff0c;每一行都是一个故事 &#x1f38f;&#xff1a;你只管努力&#xff0c;剩下的交给时间 &#x1f3e0; &#xff1a;小破站 使用AOP优化Spring Boot Controller参数&#xff1a;自动填充常用字段的技巧 前言为什么使用AOP为…

java8函数式编程学习(二):optional,函数式接口和并行流的学习

简介 java8函数式编程中optional的简单使用&#xff0c;函数式接口的了解&#xff0c;并行流的使用。 optional 可以更优雅的来避免空指针异常。类似于包装类&#xff0c;把具体的数据封装到optional对象内部&#xff0c;然后使用optional的方法去操作封装好的数据。 创建o…