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>
相关推荐
徐小夕1 天前
我们开源了一款“框架无关”的思维导图编辑器,3分钟集成到任意系统
前端·javascript·github
PBitW1 天前
GPT训练我的第三天,明白了应该咋说满分回答!😕😕😕
前端·javascript·面试
像我这样帅的人丶你还1 天前
Java 后端详解(四):分页与搜索
java·javascript·后端
摸着石头过河的石头1 天前
前端多仓库管理:从混乱到有序的进化之路
前端
星栈1 天前
写 Dioxus Demo 不难,难的是把它写成项目
前端·rust·前端框架
labixiong1 天前
还原一个完整符合规范的 Promise(二)
前端·javascript
时光足迹1 天前
腾讯云 TRTC UniApp SDK 从入门到上线
前端·vue.js·uni-app
时光足迹1 天前
uni-app 里把加密视频嵌入页面播放?我分析了 4 种方案,只有 1 种接近完美
前端·vue.js·uni-app
时光足迹1 天前
JPush UniApp UTS 插件完全参考手册:API、事件与厂商通道一网打尽
vue.js·ios·uni-app
时光足迹1 天前
极光推送全攻略(下):uni-app 代码实现与 iOS 排查实战
vue.js·ios·uni-app