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>
相关推荐
blues_C9 分钟前
十三、【核心功能篇】测试计划管理:组织和编排测试用例
vue.js·django·测试用例·drf·测试平台
谢尔登11 分钟前
【React】useId
前端·javascript·react.js
qq_3364117513 分钟前
【笔记】Chrome浏览器的性能调试(performance)工具使用和代码优化
前端·chrome·笔记
笑口常开的小丸子23 分钟前
Selenium 中 JavaScript 点击的优势及使用场景
javascript·selenium·测试工具
NoneCoder24 分钟前
Redux 实践与中间件应用
前端·react.js·中间件·面试
淡水猫.26 分钟前
Next.js 中间件鉴权绕过漏洞 CVE-2025-29927
javascript·安全·web安全·中间件
蓝胖子的多啦A梦32 分钟前
Vue3 (数组push数据报错) 解决Cannot read property ‘push‘ of null报错问题
前端·vue3·push·数组数据
祯民36 分钟前
入职阿里云一个月后,我有了新的人生体验
前端·面试·trae
iiismobi44 分钟前
React项目的状态管理:Redux Toolkit
前端·react.js·前端框架·redux toolkit
周不凢1 小时前
vue3+ts实现百度地图鼠标绘制多边形
前端·vue.js