Element Plus 的 el-table 组件合并不规律的行

在 Element Plus 的 el-table 组件中,可以使用 span-method 属性来动态合并不规律数量的行。您可以根据数据的特定条件来确定合并行的方式

复制代码
<template>
  <el-table :data="tableData" :span-method="handleSpanMethod" border>
    <el-table-column type="index" label="序号"></el-table-column>
    <el-table-column label="姓名" prop="name"></el-table-column>
    <el-table-column label="年龄" prop="age"></el-table-column>
    <el-table-column label="性别" prop="gender"></el-table-column>
  </el-table>
</template>

<script>
export default {
  data() {
    return {
      tableData: [
        { name: 'John', age: 20, gender: 'Male' },
        { name: 'Jane', age: 30, gender: 'Female' },
        { name: 'Tom', age: 35, gender: 'Male' },
        { name: 'Alice', age: 25, gender: 'Female' },
        { name: 'Bob', age: 28, gender: 'Male' },
        { name: 'Eve', age: 38, gender: 'Female' },
        { name: 'Mike', age: 40, gender: 'Male' },
        { name: 'Lily', age: 42, gender: 'Female' }
      ]
    };
  },
  methods: {
    handleSpanMethod({ row, column, rowIndex, columnIndex }) {
      if (columnIndex === 0) {
        // 合并姓名列
        if (rowIndex > 0 && row.name === this.tableData[rowIndex - 1].name) {
          // 当前行的姓名与前一行相同,则合并行
          return { rowspan: 0, colspan: 0 };
        } else {
          // 当前行的姓名与前一行不同,则不合并行
          let count = 1;
          for (let i = rowIndex + 1; i < this.tableData.length; i++) {
            if (this.tableData[i].name === row.name) {
              count++;
            } else {
              break;
            }
          }
          return { rowspan: count, colspan: 1 };
        }
      } else {
        // 其他列不合并
        return { rowspan: 1, colspan: 1 };
      }
    }
  }
};
</script>

我们在 el-table 上指定了 span-method 属性,并将其绑定到 handleSpanMethod 方法上。在 handleSpanMethod 方法中,我们根据行索引和列索引来判断是否需要合并行,并返回相应的 rowspancolspan 值。

在这个例子中,我们合并了第一列(姓名列)的行。第一行合并了三行,第四行合并了两行,其余行都不需要合并。其他列不进行合并,每行都显示单个单元格。

相关推荐
薛定猫AI12 小时前
【深度解析】Gemma Chat 本地 AI 编程 Agent:Electron + MLX + 开源模型的离线 Vibe Coding 实战
javascript·人工智能·electron
kyriewen12 小时前
Webpack vs Vite:一个是“老黄牛”,一个是“猎豹”,你选谁?
前端·webpack·vite
打小就很皮...12 小时前
html2canvas + jsPDF 生成 PDF 的踩坑与解决方案总结
前端·pdf
全栈前端老曹12 小时前
【前端地图】多地图平台适配方案——高德、百度、腾讯、Google Maps SDK 差异对比、封装统一地图接口
前端·javascript·百度·dubbo·wgs84·gcj-02·bd09
笑虾12 小时前
Win10 修改注册表 让鼠标悬停PNG上时 tip 始终显示分辨率
开发语言·javascript·ecmascript
xiaogg367813 小时前
spring oauth2 单点登录
java·vue.js·spring
雾岛听风69113 小时前
JavaScript基础语法速查手册
开发语言·前端·javascript
遇见~未来13 小时前
第三篇_现代布局_从弹性到网格
前端·css3
前端那点事13 小时前
Vue前端SEO优化全攻略(实操落地版,新手也能上手)
前端·vue.js
Dxy123931021613 小时前
HTML 如何使用 SVG 画曲线
前端·算法·html