当前位置: 首页 > 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/news/308959.html

相关文章:

  • 深度学习和机器学习的区别
  • 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建模与仿真 第十三章(信号通路库)
  • TinyML-On-The-Fly: 实时、低功耗、低成本的微控制器嵌入式设备内计算机视觉技术用于无人机图像分类
  • AtCoder ABC370 A-D题解
  • 传知代码-KAN卷积:医学图像分割新前沿
  • 使用Pydantic模型和LangChain构建高效查询过滤器
  • 为什么在 JSON 序列化中不使用 transient
  • 复变函数论重大错误:将无穷多各异平面误为同一面
  • bev pool 原理及代码讲解
  • 通信工程学习:什么是AN-SMF接入网系统管理功能
  • jacoco生成单元测试覆盖率报告
  • 使用vant UI实现时间段选择