Vue:Table合并行于列

html 复制代码
<template>
  <div>
    <el-table
      :data="tableData"
      :span-method="mergeCells"
      style="width: 100%">
      <el-table-column
        prop="date"
        label="日期"
        width="180">
      </el-table-column>
      <el-table-column
        prop="name"
        label="姓名"
        width="180">
      </el-table-column>
      <el-table-column
        prop="address"
        label="地址">
      </el-table-column>
    </el-table>
  </div>
</template>

<script>
export default {
  data() {
    return {
      tableData: [
        { date: '2023-10-01', name: 'Tom', address: 'No. 189, Grove St, Los Angeles' },
        { date: '2023-10-01', name: 'Tom', address: 'No. 189, Grove St, Los Angeles' },
        { date: '2023-10-02', name: 'Jerry', address: 'No. 189, Grove St, Los Angeles' },
        { date: '2023-10-02', name: 'Jerry', address: 'No. 189, Grove St, Los Angeles' },
        { date: '2023-10-03', name: 'Spike', address: 'No. 189, Grove St, Los Angeles' }
      ]
    };
  },
  methods: {
    mergeCells({ row, column, rowIndex, columnIndex }) {
      if (columnIndex === 0) { // 假设我们要合并的是第一列(日期列)
        const _row = this.tableData[rowIndex];
        const _prevRow = this.tableData[rowIndex - 1];
        if (_prevRow && _prevRow.date === _row.date) {
          return {
            rowspan: 0,
            colspan: 1
          };
        } else {
          let count = 1;
          for (let i = rowIndex + 1; i < this.tableData.length; i++) {
            if (this.tableData[i].date === _row.date) {
              count++;
            } else {
              break;
            }
          }
          return {
            rowspan: count,
            colspan: 1
          };
        }
      }
    }
  }
};
</script>
相关推荐
加班是不可能的,除非双倍日工资3 小时前
css预编译器实现星空背景图
前端·css·vue3
wyiyiyi3 小时前
【Web后端】Django、flask及其场景——以构建系统原型为例
前端·数据库·后端·python·django·flask
gnip4 小时前
vite和webpack打包结构控制
前端·javascript
excel4 小时前
在二维 Canvas 中模拟三角形绕 X、Y 轴旋转
前端
阿华的代码王国4 小时前
【Android】RecyclerView复用CheckBox的异常状态
android·xml·java·前端·后端
一条上岸小咸鱼4 小时前
Kotlin 基本数据类型(三):Booleans、Characters
android·前端·kotlin
Jimmy4 小时前
AI 代理是什么,其有助于我们实现更智能编程
前端·后端·ai编程
草梅友仁4 小时前
草梅 Auth 1.4.0 发布与 ESLint v9 更新 | 2025 年第 33 周草梅周报
vue.js·github·nuxt.js
ZXT5 小时前
promise & async await总结
前端
Jerry说前后端5 小时前
RecyclerView 性能优化:从原理到实践的深度优化方案
android·前端·性能优化