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>
相关推荐
傻小胖14 分钟前
ES6 迭代器 (`Iterator`)使用总结
前端·ecmascript·es6
hx_119917 分钟前
ES6-rest参数、数组扩展中的扩展运算符
前端·ecmascript·es6
顽强的22 分钟前
「前端进阶」掌握这10个JavaScript技巧,让你的代码更优雅!
javascript
逝水流光25 分钟前
Canvas系列(20):画布中画满圆
前端·游戏开发·canvas
'tubug'1 小时前
Fiddler Classic(HTTP流量代理+半汉化)
前端·http·网络安全·fiddler
格雷_代码爱好者3 小时前
wangeditor自定义粘贴
vue.js
ak啊3 小时前
开发一款 VSCode 插件
前端
进阶的小叮当4 小时前
Vue+Node调用Python并将结果显示到Web页面中
vue.js·python·node.js
DawnKylin4 小时前
【JavaScript】异步和期约
javascript