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>
相关推荐
凌泽8 分钟前
写了那么多年的代码,我开始写“规范”了:AI 驱动的开发范式革命
前端·vibecoding
没有鸡汤吃不下饭10 分钟前
解决前端项目中大数据复杂列表场景的完美方案
前端·javascript·vue.js
旧雨散尘33 分钟前
【react】react初学6-第一个react应用-待办事项
前端·react.js·前端框架
Tzarevich37 分钟前
现代JavaScript字符串处理:从基础语法到模板字符串的深度演进与技术实践
javascript
岁月向前44 分钟前
iOS基础问题整理
前端
陈随易1 小时前
改变世界的编程语言MoonBit:配置系统介绍(下)
前端·后端·程序员
jump6801 小时前
【react】 useReducer 集中式管理组件的状态
前端
许泽宇的技术分享1 小时前
把 CLI 搬上 Web:在内网打造“可二开”的 AI IDE,为什么这条路更现实?
前端·ide·人工智能
jump6801 小时前
【react】useState是什么,怎么用
前端
进击的夸父1 小时前
前端合并的表格排序功能
前端