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>
相关推荐
Ruihong3 分钟前
你的 Vue slot 插槽,VuReact 会编译成什么样的 React 代码?
vue.js·react.js·面试
Hello--_--World4 分钟前
ES15:Object.groupBy() 和 Map.groupBy()、Promise.withResolvers() 相关知识点
开发语言·前端·javascript
一 乐7 分钟前
房产租赁管理|基于springboot + vue房产租赁管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·房产租赁管理系统
Cache技术分享13 分钟前
386. Java IO API - 监控目录变化
前端·后端
Hooray20 分钟前
管理后台框架 AI 时代的版本答案,Fantastic-admin 6.0 它来了!
前端·前端框架·ai编程
2501_9136800028 分钟前
Vue3项目快速接入AI助手的终极方案 - 让你的应用智能升级
前端·vue.js·人工智能·ai·vue·开源软件
开开心心_Every30 分钟前
动图制作工具,拆分转视频动态照离线免费
运维·前端·人工智能·edge·pdf·散列表·启发式算法
饭后一颗花生米38 分钟前
2026 前端实战:AI 驱动下的性能优化与工程化升级
前端·人工智能·性能优化
YJlio1 小时前
4月14日热点新闻解读:从金融数据到平台治理,一文看懂今天最值得关注的6个信号
java·前端·人工智能·金融·eclipse·电脑·eixv3
xjf77111 小时前
AI重构前端项目指南
前端·ai·重构·编程