记录el-table的表格合并问题

项目需求背景:

利用el-table进行数据展示时,时常会有需要表格合并的情景,比如一个表格由5列组成:
类型 地区 金额 重量 长度

在这个表格里,如果同金额、重量 的列可以合并到一起,这时应该怎么做呢?查看element plus文档可以看到,对于el-table有一个span-method方法:

可以看到该属性默认返回一个函数,函数有四个参数,分别表示横行数据、纵行数据、横行索引和纵行索引,然后我们实操一下,为该参数绑定一个函数rowSpanRulesHandler,在这之前声明一个数组,数组各项表示table各列,

javascript 复制代码
const columns = ['type', 'area', 'amount', 'weight', 'length'];

然后利用switch case 列出所有需要合并的行,并在最后一个case调用合并函数:

javascript 复制代码
const rowSpanRulesHandler = ({ row, column, rowIndex, columnIndex }, data) => {
  switch (columns[columnIndex]) {
    case 'amount':
    case 'weight':
      const r = CombineColumns.compareAttrReturnColSpan(row, 'amount', rowIndex, list.value);
      return r;
    }
    default:
      return [1, 1];
  }
};

所以现在的核心就是CombineColumns函数该如何实现,先上代码:

javascript 复制代码
const compareSingleAttrReturnColSpan=(row, str, index, list) =>{
    let count = 0;
    let start = index;
    let multCompare = true;
    while (start < list.length && multCompare) {
      start++;
      count++;

      multCompare = row[str] === list[start]?.[compareAttr];
    }
    start--;

    if (start < list.length) {
      list[index][`${compareAttr}_count`] = count;
    }

    if (index > 0 && count + 1 === list[index - 1][`${compareAttr}_count`]) {
      return [0, 0];
    }

    return [count, 1];
  }

首先,初始化 count(计数器)和 start(起始位置)变量,以及一个名为 multCompare 的布尔值,用于在循环中判断是否需要继续合并。

使用一个 while 循环遍历 list,在循环中检查当前行的 compareAttr 属性值是否与下一行的相同。如果相同,则增加 count,并继续循环。否则,跳出循环。

在循环结束后,如果 start 仍然小于 list.length,则将计数器 count 分配给当前行的 ${compareAttr}_count 属性。

如果 index 大于 0,且 count + 1 等于前一行的 ${compareAttr}_count 属性值,则返回 [0, 0]。这表示当前单元格已经被合并到前一行,因此不需要额外的跨度。

否则,返回一个数组,包含 count(合并列的跨度)和 1(合并行的跨度)。

相关推荐
yuhaiqiang10 分钟前
被 AI 忽悠后,开始怀念搜索引擎了?
前端·后端·面试
红色石头本尊26 分钟前
1-umi-前端工程化搭建
前端
真夜33 分钟前
关于对echart盒子设置百分比读取的宽高没有撑开盒子解决方案
前端
楠木6851 小时前
RAG 资料库 Demo 完整开发流程
前端·ai编程
肠胃炎1 小时前
挂载方式部署项目
服务器·前端·nginx
像我这样帅的人丶你还1 小时前
使用 Next.js + Prisma + MySQL 开发全栈项目
前端
FPGA小迷弟1 小时前
FPGA 时序约束基础:从时钟定义到输入输出延迟的完整设置
前端·学习·fpga开发·verilog·fpga
Kel1 小时前
深入剖析 openai-node 源码:一个工业级 TypeScript SDK 的架构之美
javascript·人工智能·架构
毛骗导演1 小时前
@tencent-weixin/openclaw-weixin 插件深度解析(四):API 协议与数据流设计
前端·架构
毛骗导演1 小时前
@tencent-weixin/openclaw-weixin 插件深度解析(二):消息处理系统架构
前端·架构