热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

开发笔记:vue实用demo使用表格(eltable)的spanmethod属性实现表格行合并

篇首语:本文由编程笔记#小编为大家整理,主要介绍了vue实用demo使用表格(el-table)的span-method属性实现表格行合并相关的知识,希望对你有一定的参考价值。

篇首语:本文由编程笔记#小编为大家整理,主要介绍了vue实用demo使用表格(el-table)的span-method属性实现表格行合并相关的知识,希望对你有一定的参考价值。






1 demo效果

在这里插入图片描述
如上图实现表格中性别这一列实现行合并


2 实现要点


2.1 计算合并表格行所需数据

该方法的主要目的是在表格渲染前,为表格合并行准备合并所需的数据,示例中是通过表格中的性别来判断是否需要合并

// 为表格行合并准备数据
getRowList() {
this.rowList = []
this.rowListpos = 0
this.tableData.forEach((item, index, arr) => {
// 表格第一行必须保留
if (index === 0) {
this.rowList.push(1)
this.rowListpos = 0
} else {
// 判断当前行性别与上一行性别是否相同 如果相同则合并
if (item.sex === arr[index - 1].sex) {
this.rowList[this.rowListpos] += 1
this.rowList.push(0)
} else {
this.rowList.push(1)
this.rowListpos = index
}
}
})
}

2.2 配置span-method属性

el-table中的span-method属性用来配置计算合并行或列的计算方法,该属性的回调函数有四个参数row、column、rowIndex、columnIndex,该方法需要返回一个对象,这个对象包含两个属性:rowspan和colspan两个属性,rowspan表示占用行数,colspan表示占用列数,如果两个值都为0表示不用合并

// 表格合并行的计算方法
objectSpanMethod({ row, column, rowIndex, columnIndex }) {
//第三列表格合并行
if (columnIndex === 2) {
if (this.rowList[rowIndex]) {
const rowNum = this.rowList[rowIndex]
return {
rowspan: rowNum,
colspan: rowNum > 0 ? 1 : 0
}
} else {
return {
rowspan: 0,
colspan: 0
}
}
}
}

3 demo代码

<template>
<el-table :data&#61;"tableData" style&#61;"width: 40%" border :span-method&#61;"objectSpanMethod">
<el-table-column prop&#61;"date" label&#61;"日期" width&#61;"180">
</el-table-column>
<el-table-column prop&#61;"name" label&#61;"姓名" width&#61;"180">
</el-table-column>
<el-table-column prop&#61;"sex" label&#61;"性别" width&#61;"180">
</el-table-column>
<el-table-column prop&#61;"address" label&#61;"地址">
</el-table-column>
</el-table>
</template>
<script>
export default {
name: &#39;&#39;,
data() {
return {
rowList: [],
rowListpos: 0,
tableData: [
{
date: &#39;2016-05-02&#39;,
name: &#39;王小虎&#39;,
sex: &#39;男&#39;,
address: &#39;上海市普陀区金沙江路 1518 弄&#39;
},
{
date: &#39;2016-05-04&#39;,
name: &#39;王小虎&#39;,
sex: &#39;男&#39;,
address: &#39;上海市普陀区金沙江路 1517 弄&#39;
},
{
date: &#39;2016-05-01&#39;,
name: &#39;王小&#39;,
sex: &#39;女&#39;,
address: &#39;上海市普陀区金沙江路 1519 弄&#39;
},
{
date: &#39;2016-05-03&#39;,
name: &#39;王小&#39;,
sex: &#39;女&#39;,
address: &#39;上海市普陀区金沙江路 1516 弄&#39;
}
]
}
},
mounted() {
this.getRowList()
},
methods: {
// 表格合并行的计算方法
objectSpanMethod({ row, column, rowIndex, columnIndex }) {
//第三列表格合并行
if (columnIndex &#61;&#61;&#61; 2) {
if (this.rowList[rowIndex]) {
const rowNum &#61; this.rowList[rowIndex]
return {
rowspan: rowNum,
colspan: rowNum > 0 ? 1 : 0
}
} else {
return {
rowspan: 0,
colspan: 0
}
}
}
},
// 为表格行合并准备数据
getRowList() {
this.rowList &#61; []
this.rowListpos &#61; 0
this.tableData.forEach((item, index, arr) &#61;> {
// 表格第一行必须保留
if (index &#61;&#61;&#61; 0) {
this.rowList.push(1)
this.rowListpos &#61; 0
} else {
// 判断当前行性别与上一行性别是否相同 如果相同则合并
if (item.sex &#61;&#61;&#61; arr[index - 1].sex) {
this.rowList[this.rowListpos] &#43;&#61; 1 //需要合并的行数累加1
this.rowList.push(0)
} else {
this.rowList.push(1)
this.rowListpos &#61; index
}
}
})
}
}
}
</script>





推荐阅读
  • 本文讨论了在手机移动端如何使用HTML5和JavaScript实现视频上传并压缩视频质量,或者降低手机摄像头拍摄质量的问题。作者指出HTML5和JavaScript无法直接压缩视频,只能通过将视频传送到服务器端由后端进行压缩。对于控制相机拍摄质量,只有使用JAVA编写Android客户端才能实现压缩。此外,作者还解释了在交作业时使用zip格式压缩包导致CSS文件和图片音乐丢失的原因,并提供了解决方法。最后,作者还介绍了一个用于处理图片的类,可以实现图片剪裁处理和生成缩略图的功能。 ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • 预备知识可参考我整理的博客Windows编程之线程:https:www.cnblogs.comZhuSenlinp16662075.htmlWindows编程之线程同步:https ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 使用Ubuntu中的Python获取浏览器历史记录原文: ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 不同优化算法的比较分析及实验验证
    本文介绍了神经网络优化中常用的优化方法,包括学习率调整和梯度估计修正,并通过实验验证了不同优化算法的效果。实验结果表明,Adam算法在综合考虑学习率调整和梯度估计修正方面表现较好。该研究对于优化神经网络的训练过程具有指导意义。 ... [详细]
  • 利用Visual Basic开发SAP接口程序初探的方法与原理
    本文介绍了利用Visual Basic开发SAP接口程序的方法与原理,以及SAP R/3系统的特点和二次开发平台ABAP的使用。通过程序接口自动读取SAP R/3的数据表或视图,在外部进行处理和利用水晶报表等工具生成符合中国人习惯的报表样式。具体介绍了RFC调用的原理和模型,并强调本文主要不讨论SAP R/3函数的开发,而是针对使用SAP的公司的非ABAP开发人员提供了初步的接口程序开发指导。 ... [详细]
  • ASP.NET2.0数据教程之十四:使用FormView的模板
    本文介绍了在ASP.NET 2.0中使用FormView控件来实现自定义的显示外观,与GridView和DetailsView不同,FormView使用模板来呈现,可以实现不规则的外观呈现。同时还介绍了TemplateField的用法和FormView与DetailsView的区别。 ... [详细]
  • 本文讨论了clone的fork与pthread_create创建线程的不同之处。进程是一个指令执行流及其执行环境,其执行环境是一个系统资源的集合。在调用系统调用fork创建一个进程时,子进程只是完全复制父进程的资源,这样得到的子进程独立于父进程,具有良好的并发性。但是二者之间的通讯需要通过专门的通讯机制,另外通过fork创建子进程系统开销很大。因此,在某些情况下,使用clone或pthread_create创建线程可能更加高效。 ... [详细]
  • 本文介绍了深入浅出Linux设备驱动编程的重要性,以及两种加载和删除Linux内核模块的方法。通过一个内核模块的例子,展示了模块的编译和加载过程,并讨论了模块对内核大小的控制。深入理解Linux设备驱动编程对于开发者来说非常重要。 ... [详细]
  • Java自带的观察者模式及实现方法详解
    本文介绍了Java自带的观察者模式,包括Observer和Observable对象的定义和使用方法。通过添加观察者和设置内部标志位,当被观察者中的事件发生变化时,通知观察者对象并执行相应的操作。实现观察者模式非常简单,只需继承Observable类和实现Observer接口即可。详情请参考Java官方api文档。 ... [详细]
  • 本文介绍了在序列化时如何对SnakeYaml应用格式化,包括通过设置类和DumpSettings来实现定制输出的方法。作者提供了一个示例,展示了期望的yaml生成格式,并解释了如何使用SnakeYaml的特定设置器来实现这个目标。对于正在使用SnakeYaml进行序列化的开发者来说,本文提供了一些有用的参考和指导。摘要长度为169字。 ... [详细]
author-avatar
无限的天空-空间
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有