elementui的el-table自定义控制展开事件,实现“展开”“收起”的切换(两种效果)【超级完整式代码】

第一种:多行点击展开其他行不收起
先看效果图
在这里插入图片描述
直接上代码
【核心代码添加标注简单易懂】

 <el-tableref="multipleTable":data="smsLogList.slice((currentPage - 1) * pageSize_, currentPage * pageSize_)"tooltip-effect="dark"style="width: 100%"row-key="id"   【核心代码】:expand-row-keys="expands"【核心代码】><el-table-column label="短信模板" align="center" prop="templateName" /><el-table-column label="接收方" align="center" prop="receiverPhoneNumber" /><el-table-column label="发送时间" align="center" prop="sendTime" />【展开部分】<el-table-column type="expand"><template slot-scope="props"><el-form label-position="right" inline class="demo-table-expand"><el-form-item><span>{{ props.row.templateName }}</span></el-form-item></el-form></template></el-table-column>【操作列】<el-table-column label="操作" width="120"><template #default="scope"><el-linkstyle="color:#1890ff"@click="handleRowClick(scope.row)">{{ scope.row.id == expands.filter((val) => val == scope.row.id) ? "收起" : "展开" }}</el-link></template></el-table-column></el-table>
data中定义: expands:[]
handleRowClick(row) {if (this.expands.includes(row.id)) {this.expands = this.expands.filter((val) => val !== row.id)} else {this.expands.push(row.id)}},

第二种:多行点击展开其他行自动收起:手风琴效果
【修改】标注就是跟第一种代码不同的地方:两处修改

 <el-tableref="multipleTable":data="smsLogList.slice((currentPage - 1) * pageSize_, currentPage * pageSize_)"tooltip-effect="dark"style="width: 100%"row-key="id" :expand-row-keys="expands"><el-table-column label="短信模板" align="center" prop="templateName" /><el-table-column label="接收方" align="center" prop="receiverPhoneNumber" /><el-table-column label="发送时间" align="center" prop="sendTime" /><el-table-column type="expand"><template slot-scope="props"><el-form label-position="right" inline class="demo-table-expand"><el-form-item><span>{{ props.row.templateName }}</span></el-form-item></el-form></template></el-table-column><el-table-column label="操作" width="120"><template #default="scope"><el-linkstyle="color:#1890ff"@click="handleRowClick(scope.row)">{{ scope.row.id == expands[0]) ? "收起" : "展开" }}</el-link>   【修改】</template></el-table-column></el-table>
data中定义: expands:[]
handleRowClick(row) {if (this.expands.includes(row.id)) {this.expands = this.expands.filter((val) => val !== row.id)} else {this.expands=[]    【修改】this.expands.push(row.id)}},

隐藏elementUI 展开行 > 图标

::v-deep .el-table__expand-icon{visibility: hidden;
}

注意

  row-key="id"   这里是设置了每行的唯一值,所以表格数组对象中是需要有id的,如果没有可以手动添加

代码

 for (let i = 0; i < this.smsLogList.length; i++) {this.smsLogList[i].id = i + 1}

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

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

相关文章

Python拼接字符串

在Python编程中&#xff0c;字符串拼接是一项常见的操作&#xff0c;它可以用于将多个字符串连接起来形成一个新的字符串&#xff0c;是处理文本数据和字符串操作的基本技巧之一。 1. 使用""运算符进行字符串拼接 最常见的字符串拼接方法是使用""运算符&…

专业130+总分390+第二名中国海洋大学946信号与系统考研经验电子信息通信

今年专业946信号与系统130&#xff0c;总分390&#xff0c;专业排名第2顺利上岸中国海洋大学&#xff0c;总结一下自己的复习经验希望对大家复习有所帮助&#xff0c;每个人的学习习惯不同&#xff0c;大家要对自己有信心&#xff0c;借鉴加上自己整合&#xff0c;属于自己的才…

在Windows上安装与配置Apache服务并结合内网穿透工具实现公网远程访问本地内网服务

文章目录 前言1.Apache服务安装配置1.1 进入官网下载安装包1.2 Apache服务配置 2.安装cpolar内网穿透2.1 注册cpolar账号2.2 下载cpolar客户端 3. 获取远程桌面公网地址3.1 登录cpolar web ui管理界面3.2 创建公网地址 4. 固定公网地址 前言 Apache作为全球使用较高的Web服务器…

Git 教程 | 将本地修改后的文件推送到 Github 指定远程分支上

Git 是一种分布式版本控制系统&#xff0c;用于敏捷高效地处理任何大小的项目。它是由 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的开源版本控制软件。Git 的本地克隆就是一个完整的版本控制存储库&#xff0c;无论脱机还是远程都能轻松工作。开发人员会在本地提交其工…

【JavaScript 基础入门】01 编程语言和计算机基础

编程语言和计算机基础 目录 编程语言和计算机基础1 - 编程语言1.1 编程1.2 计算机语言1.3 编程语言1.4 翻译器1.5 编程语言和标记语言区别1.6 总结 2 - 计算机基础2.1 计算机组成2.2 数据存储2.3 数据存储单位2.4 程序运行 1 - 编程语言 1.1 编程 编程&#xff1a; 就是让计算…

Qt线程高级应用

一般我们在用Qt开发时&#xff0c;把耗时操作放在线程中执行&#xff0c;避免卡界面&#xff0c;Qt的线程使用有两种方式&#xff0c;一种是继承QThread&#xff0c;一种是moveToThread的方式&#xff0c;以及QtConcurrent方式 首先我们来看第一种&#xff1a; #ifndef WORKER…

上推加载更多组件

本组件使用的是TaroReact 实现的 &#xff0c;具体代码如下 一共分为tsx和less文件 //index.tsx /** RefreshLoading* description 上推加载更多组件* param loading boolean* param style* returns*/import { View } from "tarojs/components"; import React, { FC…

DELL R740 两个raid10安装centos7.9

DELL R740 两个raid10安装centos7.9 服务器硬件配置&#xff1a; DELL R740&#xff1a;R740/4214R (12C,100W,2.4GHz)*2/128G(32G DDR4 RDIMM)*4 /600G SAS 10K *41.2T SAS 转速10K*4/H750 &#xff08;8G 缓存&#xff09;/750W *2/iDRAC9 要求&#xff1a;600G*4&#xf…

HTML5+CSS3小实例:创意修剪路径图像悬停效果

实例:创意修剪路径图像悬停效果 技术栈:HTML+CSS 效果: 源码: 【HTML】 <!DOCTYPE html> <html lang="zh-CN"><head><meta charset="UTF-8" /><meta http-equiv="X-UA-Compatible" content="IE=edge&qu…

安卓手机日程不响铃或弹窗提醒怎么设置?

在庞大的安卓手机用户群体中&#xff0c;诸多手机品牌如小米、OPPO、vivo、荣耀等都为用户提供了丰富的功能和便捷的体验。然而&#xff0c;有时候我们在手机日历中设置了提醒时间&#xff0c;却发现安卓手机的日程提醒并没有如期响铃或弹窗&#xff0c;这着实令人头疼。那么安…

内网安全:Exchange服务

目录 Exchange服务 实验环境 域横向移动-内网服务-Exchange探针 一. 端口扫描 二. SPN扫描 三. 脚本探针(还可以探针是否有安全漏洞) 域横向移动-内网服务-Exchange爆破 一 .BurpSuite Intruder模块爆破 域横向移动-内网服务-Exchange漏洞 CVE-2020-17144 Exchange R…

再学http

HTTP状态码 1xx 信息性状态码 websocket upgrade 2xx 成功状态码 200 服务器已成功处理了请求204(没有响应体)206(范围请求 暂停继续下载) 3xx 重定向状态码 301(永久) &#xff1a;请求的页面已永久跳转到新的url302(临时) &#xff1a;允许各种各样的重定向&#xff0c;一般…