当前位置: 首页 > article >正文

vue table id一样的列合并

合并场景:如果id一样,则主表列合并,子表列不做合并,可实现单行、多行合并,亲测!!!
展示效果如图示:
在这里插入图片描述
组件代码:

// table组件  :span-method="objectSpanMethod" 一定要有这个方法,合并逻辑都在这个里面
	<el-table
			:data="dataList"
			:span-method="objectSpanMethod"
			border
		>
			<el-table-column prop="className" label="班级" />
			<el-table-column prop="name" label="姓名" />
			<el-table-column prop="sex" label="性别"  />
			<el-table-column prop="dataType" label="科目" />
			<el-table-column prop="score" label="分数" />
		</el-table>

js代码:

//数据格式
dataList: [
				{id:"1",className:"3-1",name:"张三",sex:"男",dataType:"数学",score:"81"},
				{id:"1",className:"3-1",name:"张三",sex:"男",dataType:"英语",score:"33"},
				{id:"1",className:"3-1",name:"张三",sex:"男",dataType:"历史",score:"66"},
				{id:"2",className:"3-2",name:"李四",sex:"女",dataType:"科学",score:"13"},
				{id:"2",className:"3-2",name:"李四",sex:"女",dataType:"英语",score:"90"},
			],

//合并的js逻辑  需要合并多少列就写几列
objectSpanMethod({row, column, rowIndex, columnIndex}) {
			const _row = this.flitterData(this.dataList).one[rowIndex];
			const _col = _row > 0 ? 1 : 0;
			//合并第一列
			if (columnIndex === 0) {
				return {
					rowspan: _row,
					colspan: _col,
				};
			}
			//合并第二列
			if (columnIndex === 1) {
				return {
					rowspan: _row,
					colspan: _col,
				};
			}
			//合并第三列
			if (columnIndex === 2) {
				return {
					rowspan: _row,
					colspan: _col,
				};
			}
		},
		flitterData(arr) {
			let spanOneArr = [];
			let concatOne = 0;
			arr.forEach((item, index) => {
				if (index === 0) {
					spanOneArr.push(1);
				} else {
					// 如果id一样,就合并,根据自己的需求来改,id换为要比较的列名
					if (item.id == arr[index - 1].id) {
						spanOneArr[concatOne] += 1;
						spanOneArr.push(0);
					} else {
						spanOneArr.push(1);
						concatOne = index;
					}
				}
			});
			return {
				one: spanOneArr,
			};
		},

http://www.kler.cn/a/308959.html

相关文章:

  • Windows C++ TCP/IP 两台电脑上互相传输字符串数据
  • HTTP常见的请求头有哪些?都有什么作用?在 Web 应用中使用这些请求头?
  • C++模板特化实战:在使用开源库boost::geometry::index::rtree时,用特化来让其支持自己的数据类型
  • ctfshow-web入门-SSTI(web361-web368)上
  • 【含开题报告+文档+PPT+源码】基于Spring Boot智能综合交通出行管理平台的设计与实现
  • 《MYSQL45讲》kill不掉的线程
  • 深度学习和机器学习的区别
  • linux-安全管理-用户认证
  • leetcode 345.翻转字符串中的元音字母
  • 浅谈住房城乡建设部科技创新平台布局重点方向
  • 代码随想录Day 48|单调栈,leetcode题目:739. 每日温度、496.下一个更大元素 I、503.下一个更大元素II
  • Reactive 编程-Vert.x
  • 云原生(Cloud Native)简介及相关技术
  • 3分钟了解 跨网文件安全交换的最佳方案是什么
  • nano在shell编程中的作用
  • LLM Prompt
  • wordpress源码资源站整站打包32GB数据,含6.7W条资源数据
  • Python元组详解
  • Linux:RPM软件包管理以及yum软件包仓库
  • 工业园生活污水处理设备产地货源
  • 提问即创作:用Prompt提示词引领AI灵感爆发
  • 云原生(Cloud Native)
  • PHP安全
  • JSON 数据 Excel 行转列
  • Gradio导入AIGC大模型创建web端智能体聊天机器人,python(2)
  • Matlab simulink建模与仿真 第十三章(信号通路库)