ElementUI实现el-table组件的合并行功能

前言

有时遇到一些需求,需要实现ElementUI中,el-tabled组件合并单元格的功能,稍微了解一下它的数据格式,不难可以写出比合并方法。但是在鼠标经过单元行时,会出现高亮的行与鼠标经过的行不一致的BUG。因此还需要实现@cell-mouse-enter和@cell-mouse-leave这两个方法,才可解决此问题。

一、多列合并

1.示例代码

<template><div class="merge-cell"><div class="merge-cell-navbar">记录一下 el-table 合并行小技巧</div><div class="merge-cell-content"><div class="merge-cell-content-container"><el-table:data="tableData"borderheight="100%":header-cell-style="{padding: '4px', // 设置Table表头单元内边距backgroundColor: '#e7f0ff', // 设置Table表头背景颜色borderColor: '#b6d1ff', // 设置Table表头边框颜色color: '#000', // 设置Table表头文字颜色fontSize: '13px', // 设置Table表头文字大小fontWeight: 'normal', // 设置Table表头文字粗细}":span-method="handleSpanMethod":row-class-name="handleRowClassName"@cell-mouse-enter="handleCellMouseEnter"@cell-mouse-leave="handleCellMouseLeave"><el-table-column prop="zone" label="GameZone / 服务器区域 / 游戏区域" align="center" /><el-table-column prop="career" label="职业" width="180" align="center" /><el-table-column label="英雄" align="center"><el-table-column prop="hero" label="英雄姓名" width="280" align="center" /><el-table-column prop="firstSkill" label="一技能" width="220" align="center" /><el-table-column prop="secondSkill" label="二技能" width="220" align="center" /><el-table-column prop="thirdSkill" label="三技能" width="220" align="center" /><el-table-column label="操作" width="180" align="center"><template #default="scope"><el-tooltip effect="dark" content="收藏" placement="top" :enterable="false" :hide-after="0" @click="handleEditClick(scope.$index, scope.row)"><el-button size="small" circle><el-icon size="18"><StarFilled /></el-icon></el-button></el-tooltip></template></el-table-column></el-table-column></el-table></div></div></div>
</template><script>
export default {data: () => ({tableData: [{zone: "王者一区",career: "坦克",hero: "亚瑟",firstSkill: "誓约之盾",secondSkill: "回旋打击",thirdSkill: "圣剑裁决",},{zone: "王者一区",career: "坦克",hero: "吕布",firstSkill: "方天画斩",secondSkill: "贪狼之握",thirdSkill: "魔神降世",},{zone: "王者一区",career: "坦克",hero: "项羽",firstSkill: "无畏冲锋",secondSkill: "破釜沉舟",thirdSkill: "霸王斩杀",},{zone: "王者一区",career: "战士",hero: "云缨",firstSkill: "断月",secondSkill: "追云",thirdSkill: "逐星",},{zone: "王者一区",career: "战士",hero: "赵怀真",firstSkill: "拨云见明",secondSkill: "气定神凝",thirdSkill: "阴阳逆转",},{zone: "王者二区",career: "刺客",hero: "镜",firstSkill: "开锋",secondSkill: "裂空",thirdSkill: "见影",},{zone: "王者二区",career: "刺客",hero: "澜",firstSkill: "破浪",secondSkill: "断空",thirdSkill: "处决",},{zone: "王者二区",career: "刺客",hero: "李白",firstSkill: "将进酒",secondSkill: "神来之笔",thirdSkill: "青莲剑歌",},{zone: "王者三区",career: "法师",hero: "妲己",firstSkill: "灵魂冲击",secondSkill: "偶像魅力",thirdSkill: "女王崇拜",},{zone: "王者三区",career: "射手",hero: "后羿",firstSkill: "多重箭矢",secondSkill: "落日余晖",thirdSkill: "灼日之矢",},{zone: "王者三区",career: "射手",hero: "鲁班7号",firstSkill: "河豚手雷",secondSkill: "无敌鲨嘴炮",thirdSkill: "空中支援",},{zone: "王者三区",career: "辅助",hero: "孙膑",firstSkill: "时空爆弹",secondSkill: "时之波动",thirdSkill: "时光流逝",},{zone: "王者三区",career: "辅助",hero: "庄周",firstSkill: "化蝶",secondSkill: "蝴蝶效应",thirdSkill: "天人合一",},],first_row: {},second_row: {},}),methods: {/*** 合并单元格句柄方法*/handleSpanMethod({row, // 行column, // 列rowIndex, // 行索引columnIndex, // 列索引}) {if (columnIndex === 0 || columnIndex === 1) {// 获取当前单元格的值const currentValue = row[column.property];// 获取上一行相同列的值const preRow = this.tableData[rowIndex - 1];const preValue = preRow ? preRow[column.property] : null;// 如果当前值和上一行的值相同,则将当前单元格隐藏if (currentValue === preValue) {return {rowspan: 0, colspan: 0 };} else {// 否则计算当前单元格应该跨越多少行let rowspan = 1;for (let i = rowIndex + 1; i < this.tableData.length; i++) {const nextRow = this.tableData[i];const nextValue = nextRow[column.property];if (nextValue === currentValue) {rowspan++;} else {break;}}return {rowspan, colspan: 1 };}}},/*** 鼠标移入表格事件句柄方法*/handleCellMouseEnter(row, column, cell, event) {this.second_row = this.tableData.filter((item) => {return this.filterSameKeys(item, row, ["zone", "career"]);})[0];this.first_row = this.tableData.filter((item) => {return this.filterSameKeys(item, row, ["zone"]);})[0];},/*** 鼠标移出表格事件句柄方法*/handleCellMouseLeave() {this.currentIndex = "";this.currentColumnIndex = "";this.first_row = {};this.second_row = {};},/*** 根据 keys 数组所有字段去做合并*/filterSameKeys(item, row, keys) {let flag = true;keys.forEach((key) => {flag = flag && item[key] === row[key];});return flag;},/*** 给表格行添加自定义类名*/handleRowClassName({row }) {let flag1 = this.first_row == row ? "first_row" : "";let flag2 = this.second_row == row ? "second_row" : "";return `${flag1} ${flag2}`;},},
};
</script><style lang="less" scoped>.merge-cell {display: flex;flex-direction: column;position: relative;width: 100%;height: 100%;overflow: hidden;.merge-cell-navbar {position: relative;width: 100%;height: 100px;background-color: #686868;text-align: center;line-height: 100px;color: #fff;font-size: 25px;}.merge-cell-content {position: relative;flex: 1;padding: 100px;overflow: hidden;.merge-cell-content-container {position: relative;width: 100%;height: 100%;overflow: auto;}}:deep(.el-table) {td .cell {padding: 2.5px 0;color: #686868;font-size: 13px;}.first_row td:nth-child(1),.second_row td:nth-child(1),.first_row.second_row td:nth-child(2) {background: #f5f7fa !important;}}/* ^ 设置Table表格边框颜色 */:deep(.el-table--border) {&::before {background-color: #b6d1ff;}&::after {background-color: #b6d1ff;}.el-table__cell {border-color: #b6d1ff;}.el-table__inner-wrapper {&::before {background-color: #b6d1ff;}&::after {background-color: #b6d1ff;}.el-table__border-left-patch {background-color: #b6d1ff;}}}/* / 设置Table表格边框颜色 */}
</style>

2.运行效果

二、单列合并

1.示例代码

<template><div class="merge-cell"><div class="merge-cell-navbar">记录一下 el-table 合并行小技巧</div><div class="merge-cell-content"><div class="merge-cell-content-container"><el-table:data="tableData"borderheight="100%":header-cell-style="{padding: '4px', // 设置Table表头单元内边距backgroundColor: '#e7f0ff', // 设置Table表头背景颜色borderColor: '#b6d1ff', // 设置Table表头边框颜色color: '#000', // 设置Table表头文字颜色fontSize: '13px', // 设置Table表头文字大小fontWeight: 'normal', // 设置Table表头文字粗细}":span-method="handleSpanMethod"><el-table-column prop="zone" label="GameZone / 服务器区域 / 游戏区域" align="center" /><el-table-column prop="career" label="职业" width="180" align="center" /><el-table-column label="英雄" align="center"><el-table-column prop="hero" label="英雄姓名" width="280" align="center" /><el-table-column prop="firstSkill" label="一技能" width="220" align="center" /><el-table-column prop="secondSkill" label="二技能" width="220" align="center" /><el-table-column prop="thirdSkill" label="三技能" width="220" align="center" /><el-table-column label="操作" width="180" align="center"><template #default="scope"><el-tooltip effect="dark" content="收藏" placement="top" :enterable="false" :hide-after="0" @click="handleEditClick(scope.$index, scope.row)"><el-button size="small" circle><el-icon size="18"><StarFilled /></el-icon></el-button></el-tooltip></template></el-table-column></el-table-column></el-table></div></div></div>
</template><script>
export default {data: () => ({tableData: [{zone: "王者一区",career: "坦克",hero: "亚瑟",firstSkill: "誓约之盾",secondSkill: "回旋打击",thirdSkill: "圣剑裁决",},{zone: "王者一区",career: "坦克",hero: "吕布",firstSkill: "方天画斩",secondSkill: "贪狼之握",thirdSkill: "魔神降世",},{zone: "王者一区",career: "坦克",hero: "项羽",firstSkill: "无畏冲锋",secondSkill: "破釜沉舟",thirdSkill: "霸王斩杀",},{zone: "王者一区",career: "战士",hero: "云缨",firstSkill: "断月",secondSkill: "追云",thirdSkill: "逐星",},{zone: "王者一区",career: "战士",hero: "赵怀真",firstSkill: "拨云见明",secondSkill: "气定神凝",thirdSkill: "阴阳逆转",},{zone: "王者二区",career: "刺客",hero: "镜",firstSkill: "开锋",secondSkill: "裂空",thirdSkill: "见影",},{zone: "王者二区",career: "刺客",hero: "澜",firstSkill: "破浪",secondSkill: "断空",thirdSkill: "处决",},{zone: "王者二区",career: "刺客",hero: "李白",firstSkill: "将进酒",secondSkill: "神来之笔",thirdSkill: "青莲剑歌",},{zone: "王者三区",career: "法师",hero: "妲己",firstSkill: "灵魂冲击",secondSkill: "偶像魅力",thirdSkill: "女王崇拜",},{zone: "王者三区",career: "射手",hero: "后羿",firstSkill: "多重箭矢",secondSkill: "落日余晖",thirdSkill: "灼日之矢",},{zone: "王者三区",career: "射手",hero: "鲁班7号",firstSkill: "河豚手雷",secondSkill: "无敌鲨嘴炮",thirdSkill: "空中支援",},{zone: "王者三区",career: "辅助",hero: "孙膑",firstSkill: "时空爆弹",secondSkill: "时之波动",thirdSkill: "时光流逝",},{zone: "王者三区",career: "辅助",hero: "庄周",firstSkill: "化蝶",secondSkill: "蝴蝶效应",thirdSkill: "天人合一",},],first_row: {},second_row: {},}),methods: {/*** 合并单元格句柄方法*/handleSpanMethod({row, // 行column, // 列rowIndex, // 行索引columnIndex, // 列索引}) {const rowspanArr = this.formatRowspanAndColspan(this.tableData, 'zone')if (columnIndex === 0) {// console.log('row =>', row)// console.log('column =>', column)// console.log('rowIndex =>', rowIndex)// console.log('columnIndex =>', columnIndex)// console.log('\n')return {rowspan: rowspanArr[rowIndex],colspan: 1}}},/*** 合并单元格辅助 */formatRowspanAndColspan(tableList, keyName) {const keyNameList = []tableList.forEach(t => {keyNameList.push(t[keyName])})// console.log('keyNameList =>', keyNameList)let prev // 上一个键名的索引let contin = 0 // 连续相同键名个数const computedList = [] // 计算后的键名列表for (let i = 0; i < keyNameList.length; i++) {if (computedList.length === 0) {computedList.push({'key': keyNameList[i], 'val': 1 })} else {if (keyNameList[prev] === keyNameList[i]) {contin++computedList.push({'key': keyNameList[i], 'val': 0 })} else {if (contin > 0) {const index = computedList.length - 1 - continconst key = computedList[index].keyconst val = computedList[index].valconst obj = {'key': key, 'val': val + contin}computedList.splice(index, 1, obj)}computedList.push({'key': keyNameList[i], 'val': 1 })contin = 0}}prev = i // 将 i 赋值给 prev,以便当下一次循环时获取上一个键值的索引}if (contin > 0) {const index = computedList.length - 1 - continconst key = computedList[index].keyconst val = computedList[index].valconst obj = {'key': key, 'val': val + contin}computedList.splice(index, 1, obj)}// console.log('computedList =>', computedList)const finalList = []computedList.forEach(t => {finalList.push(t.val)})// console.log('finalList =>', finalList)return finalList},},
};
</script><style lang="less" scoped>.merge-cell {display: flex;flex-direction: column;position: relative;width: 100%;height: 100%;overflow: hidden;.merge-cell-navbar {position: relative;width: 100%;height: 100px;background-color: #686868;text-align: center;line-height: 100px;color: #fff;font-size: 25px;}.merge-cell-content {position: relative;flex: 1;padding: 100px;overflow: hidden;.merge-cell-content-container {position: relative;width: 100%;height: 100%;overflow: auto;}}:deep(.el-table) {td .cell {padding: 2.5px 0;color: #686868;font-size: 13px;}.first_row td:nth-child(1),.second_row td:nth-child(1),.first_row.second_row td:nth-child(2) {background: #f5f7fa !important;}}/* ^ 设置Table表格边框颜色 */:deep(.el-table--border) {&::before {background-color: #b6d1ff;}&::after {background-color: #b6d1ff;}.el-table__cell {border-color: #b6d1ff;}.el-table__inner-wrapper {&::before {background-color: #b6d1ff;}&::after {background-color: #b6d1ff;}.el-table__border-left-patch {background-color: #b6d1ff;}}}/* / 设置Table表格边框颜色 */}
</style>

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

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

相关文章

8月刷题笔记

刷题笔记—8月 LCP40.心算挑战(贪心、排序) class Solution { public:int maxmiumScore(vector<int>& cards, int cnt) {//24.8.1ranges::sort(cards, greater()); //从大到小排序int s reduce(cards.begin(), cards.begin()cnt, 0);if(s%2 0) return s;auto rep…

无线麦克风哪个牌子的好,麦克风哪个好,无线麦克风品牌推荐

​在自媒体日益繁荣的当下&#xff0c;内容创作成为了许多人追求的目标。对于视频内容创作者而言&#xff0c;出色的内容是成功的基石&#xff0c;而高质量的设备则是保证作品品质的关键。为了提升视频音质&#xff0c;拥有一款专业的无线麦克风是不可或缺的。 然而&#xff0…

PHP智能匹配轻松预订自习室在线订座系统小程序源码

智能匹配&#xff0c;轻松预订——自习室在线订座系统 &#x1f4da;【开篇&#xff1a;告别排队&#xff0c;迎接智能学习新时代】&#x1f4da; 还在为找不到合适的自习室座位而烦恼吗&#xff1f;是不是每次去图书馆或自习室都要提前好久去排队占位&#xff1f;现在&#…

太速科技-1路万兆光纤SFP+和1路千兆网络 FMC子卡模块

1路万兆光纤SFP和1路千兆网络 FMC子卡模块 一、概述 该板卡是基于kc705和ml605的fmc 10g万兆光纤扩展板设计&#xff0c;提供了1路万兆光纤SFP和1路千兆网络接口。可搭配我公司开发的FPGA载卡使用。载卡可参考&#xff1a;ID204 SFP&#xff08;10 Gigabit Small…

AWS-亚马逊网络服务(基础服务)-AWS 定价计算器-概述与动手部署:

让我们来概述并亲身实践如何使用 AWS 定价计算器来计算 概述&#xff1a; AWS 定价计算器是 Amazon Web Services (AWS) 提供的基于 Web 的工具&#xff0c;可帮助用户估算其特定用例的 AWS 服务成本。欢迎来到雲闪世界。 它允许客户建模他们的基础设施并根据他们打算使用的…

Android 9.0 增加interface audio接口,解决编译报错

最近修改Android接口&#xff0c;报了一个VNDK的错误 我总结了如下几种方式&#xff1a; 1、直接关闭&#xff08;不推荐&#xff09;&#xff1a; 在BoardConfig.mk中加入如下两行&#xff0c;可以在编译的时候不去check VNDK&#xff0c;关掉这个可能会导致XTS某些测项跑不…

Burp Suite Professional 2024.8 for macOS x64 ARM64 - 领先的 Web 渗透测试软件

Burp Suite Professional 2024.8 for macOS x64 & ARM64 - 领先的 Web 渗透测试软件 世界排名第一的 Web 渗透测试工具包 请访问原文链接&#xff1a;https://sysin.org/blog/burp-suite-pro-mac/&#xff0c;查看最新版。原创作品&#xff0c;转载请保留出处。 作者主页…

Linux内核编程(十五)网络设备驱动

本文目录 一、常见的网络协议二、传输介质三、RJ-45接口 对于网络知识不太熟悉的同学可以查看这篇文章&#xff1a;计算机网络知识点详情总结。 一、常见的网络协议 TCP、UDP协议&#xff1a;详情查看-TCP、UDP系统编程。DNS协议&#xff1a;是互联网中用于将域名&#xff08…

RocketMQ集群搭建,及RocketMQ-Dashboard部署(前RocketMQ-Console)

集群搭建 RocketMQ不支持单主机搭建主从结构集群&#xff0c;当从节点启动时&#xff0c;即使和主节点设置不同的监听端口&#xff0c;他也要去监听主节点端口&#xff0c;也就是说正常启动的从节点会监听四个端口。原因未知&#xff0c;现象后面会列举出来。 1. 准备JAVA环境…

在 Ubuntu 环境下使用 VSCode 和 PlatformIO 下载程序到 Arduino Uno

安装 VSCode 访问 VSCode 官网 下载 .deb 包使用以下命令安装&#xff1a;sudo dpkg -i <下载的文件名>.deb sudo apt-get install -f安装 PlatformIO 扩展 在 VSCode 中&#xff0c;转到扩展市场&#xff08;CtrlShiftX&#xff09;搜索 “PlatformIO IDE”点击 “安装”…

STM32 HAL CAN (TJA1050CAN模块) 通讯(一)理论

1、简介 CAN具备多个设备交互的能力,但是网上大多是两个单片机进行交互,或者单片机通过CAN收发器与上位机进行交互测试,本次通过STM32cubeMX完成CAN通讯配置,并通过多个单片机进行数据交互测试。 2、CAN简介 CAN是一种串行通讯协议,主要有低速、高速CAN两种。 低速CAN…

相亲交友系统商业开发

在快节奏的现代生活中&#xff0c;寻找真爱成为了许多人的渴望。相亲交友系统&#xff0c;作为连接心灵的桥梁&#xff0c;正逐渐成为人们寻找伴侣的首选方式。我们的团队h17711347205致力于开发一款创新的相亲交友系统&#xff0c;旨在通过智能化的匹配算法&#xff0c;为用户…

Android UID 和 userID 以及 appID

我们知道Android 操作系统是基于Linux内核的&#xff0c;所以Android 的UID 是基于 Linux UID的。 Linux UID Linux 本身就是一个多用户操作系统&#xff0c;每一个用户都会有一个UID&#xff0c;不同UID 之间的资源访问是受限的。 其中&#xff0c;Linux的DAC权限模型&#…

【UE5】控件蓝图——树视图(TreeView)的基本使用

目录 前言 效果 步骤 一、显示根节点 二、显示子节点 前言 我们在视口中添加1个方块&#xff0c;2个球体&#xff0c;5个圆柱 它们在大纲视图中的层级关系如下&#xff0c;那么如何将这种层级关系显示在树视图中是本篇文章要解决的问题。 效果 步骤 一、显示根节点 1…

[STM32]从零开始的STM32标准库环境搭建(小白向)

一、我们为什么要搭建STM32标准库开发环境 如果你对STM32有一定的了解&#xff0c;相信你已经认识了STM32的几种开发方式。基于STM32寄存器开发&#xff0c;基于ST官方的标准库开发&#xff0c;基于ST官方的HAL库开发。我们现在来了解一下这些库的优缺点。首先就是基于寄存器开…

macos USB外接键盘ctrl键绑定方法 解决外接USB键盘与mac键盘不一致问题

mac电脑外接USB键盘后我们需要修改一下 ctrl键的绑定后才符合我们的使用习惯,因为标准USB键盘和mac键盘上面的ctrl键是不一样的, mac上面的 command 键 对应我们USB键盘上面的 ctrl 键. 修改方法: 偏好设置 --> 键盘 点击修饰键 后 选择键盘里面选择 USB键盘 ,然后调换…

Leetcode JAVA刷刷站(111)二叉树的最小深度

一、题目概述 二、思路方向 在Java中&#xff0c;要找出二叉树的最小深度&#xff0c;我们可以使用递归的方法。基本思路是&#xff0c;对于给定的根节点&#xff0c;如果它是空的&#xff0c;那么最小深度为0&#xff08;但实际上&#xff0c;空树没有深度&#xff0c;但在…

Sui Hacker House曼谷站报名开启:在Devcon 2024期间探索Sui区块链创新

Sui 曼谷 Hacker House 报名开启 Sui Bangkok Hacker House 将在曼谷于 2024 年 11 月 4 日至 17 日举办。诚邀开发者深入学习 Move 语言,在 Sui 网络上构建 MVP ,在充满活力的曼谷中度过难忘的两周。 诚挚地邀请开发者加入为期两周的 Sui Bangkok Hacker House。 你将与其他…

构建全景式智慧文旅生态:EasyCVR视频汇聚平台与AR/VR技术的深度融合实践

在科技日新月异的今天&#xff0c;AR&#xff08;增强现实&#xff09;和VR&#xff08;虚拟现实&#xff09;技术正以前所未有的速度改变着我们的生活方式和工作模式。而EasyCVR视频汇聚平台&#xff0c;作为一款基于云-边-端一体化架构的视频融合AI智能分析平台&#xff0c;可…

ubuntu 常见问题的收录

在使用过程中&#xff0c;发现ubuntu的问题一点不必windows少。因为每次遇到问题都需要要上网找&#xff0c;所以收集起来之后就会方便一些。 版本体验 24.04&#xff1a;整体的风格大变样&#xff0c;更趋近于“现代化”&#xff1f;反正我是更喜欢了 &#x1f604;。就着风…