记录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(合并行的跨度)。

相关推荐
漂流瓶jz7 小时前
Webpack如何实现万物皆可import?loader的使用/配置/手写实践
前端·javascript·webpack
ZC跨境爬虫7 小时前
跟着 MDN 学CSS day_41:显式轨道、隐式网格与区域命名放置
前端·javascript·css·ui·交互
修己xj8 小时前
告别手动存图!这款叫 Fatkun 的浏览器插件,简直是素材收集神器
前端
袋鼠云数栈8 小时前
从前端到基础设施,ACOS 如何打通企业全链路可观测
运维·前端·人工智能·数据治理·数据智能
AskHarries9 小时前
系统提示词、开发者指令和用户输入的优先级
java·前端·数据库
Moment9 小时前
长上下文会最终杀死 Rag 吗?
前端·javascript·后端
qcx239 小时前
【系统学AI】25 论文导读 ①:两篇改变 AI 的开山之作——Attention Is All You Need & ReAct
前端·人工智能·react.js·transformer
kyriewen10 小时前
大文件上传最全指南:分片、断点续传、秒传,一篇就够了
前端·javascript·面试
我叫黑大帅11 小时前
解决聊天页内部滚轮改为页面滚动问题
javascript·后端·面试
郑洁文11 小时前
基于Python的Web命令执行漏洞自动化检测系统
前端·python·网络安全·自动化