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

相关推荐
潇凝子潇11 分钟前
使用英伟达免费调用多家大模型API
java·前端·javascript
旷世奇才李先生25 分钟前
Vue 3\+Vite\+Pinia实战:前端工程化与组件化开发全指南
前端·vue.js
Beginner x_u29 分钟前
前端八股整理(手写 01)|Promise 超时控制、红绿灯与 Promise.all
前端·javascript·promise
周bro29 分钟前
vue2+element ui 中的el-table表格 选中当前行当前行变色,单选/多选--------续集:表格样式修改整合
vue.js·ui·elementui
万少10 小时前
Vibe Coding不停歇,移动端 TRAE SOLO 让你用手机也能编程啦
前端·javascript·后端
kyriewen1110 小时前
WebAssembly:前端界的“外挂”,让C++代码在浏览器里跑起来
开发语言·前端·javascript·c++·单元测试·ecmascript
烛衔溟11 小时前
TypeScript 接口的基本使用 —— 定义对象形状
前端·javascript·typescript
铁皮饭盒12 小时前
成为AI全栈 - 第3课:路由 RESTful Elysia 状态码 设计规范
前端·后端·全栈
顾昂_12 小时前
Web 性能优化完全指南
前端·面试·性能优化
IT乐手12 小时前
Claude Code + Qwen 的配置方法
javascript·claude