el-table :span-method 合并单元格(2.0)

2024.11.23今天我学习了如何使用el-table组件的合并单元格方法,效果如下:

代码如下:

javascript 复制代码
<template>
  <div class="container">
    <el-table :data="table_data" :span-method="object_merge" border>
      <el-table-column label="名称" prop="name" align="center"/>
      <el-table-column label="单价" prop="price" align="center"/>
      <el-table-column label="时间" prop="time" align="center"/>
    </el-table>
  </div>
</template>
<script>
export default {
  data() {
    return {
      table_data: [],//存放表格数据
      length_data: [],//存放相同数据的个数
    }
  },
  created() {
    this.get_list();
  },
  methods: {
    get_list() {
      let demo = [
        { name: '苹果', price: 20, time: '07:00:00', id: 1 },
        { name: '香蕉', price: 12, time: '08:00:00', id: 2 },
        { name: '苹果', price: 23, time: '09:00:00', id: 1 },
        { name: '西瓜', price: 30, time: '07:00:00', id: 3 },
        { name: '苹果', price: 11, time: '19:00:00', id: 1 },
        { name: '香蕉', price: 20, time: '10:00:00', id: 2 },
      ];
      // 合并相同的id
      let new_demo = demo.reduce((arr, cur) => {
        if (!arr[cur.id]) {
          arr[cur.id] = [];
        }
        arr[cur.id].push(cur);
        return arr;//注意返回
      }, {});

      this.table_data = Object.values(new_demo).flat();//数组扁平化,如[[1,2],3]变成一维数组[1,2,3]

      // 获取相同数据的长度,如果长度大于1,需要填充n-1个0
      let length_data = [];
      Object.values(new_demo).forEach(item => {
        length_data.push(item.length);
        if (item.length > 1) {
          length_data.push(...new Array(item.length - 1).fill(0));
        }
      })
      this.length_data = length_data;
    },
    // 合并数组
    object_merge({ row, column, rowIndex, columnIndex}) {
      if (columnIndex === 0) {//判断第一列
        const row_span = this.length_data[rowIndex];
        const col_span = row_span > 0 ? 1 : 0;
        return {
          rowspan: row_span,
          colspan: col_span
        }
      }
    }
  }
}
</script>

封装方法:

复制代码
1.utils  el-table-span-method.js文件
javascript 复制代码
// el-table合并单元格方法
// repeat_data_length 重复数据长度如[1,2,0,1,1,3,0,0];长度大于1需要填充n-1个0
export function el_table_merge_cell({row, column, rowIndex, columnIndex}, repeat_data_length) {
    if (columnIndex === 0) {//判断第一列
        const row_span = repeat_data_length[rowIndex];
        const col_span = row_span > 0 ? 1 : 0;
        return {
            rowspan: row_span,
            colspan: col_span
        }
    }
}

页面代码:

javascript 复制代码
<template>
  <div class="container">
    <el-table :data="table_data" :span-method="object_merge" border>
      <el-table-column label="名称" prop="name" align="center"/>
      <el-table-column label="单价" prop="price" align="center"/>
      <el-table-column label="时间" prop="time" align="center"/>
    </el-table>
  </div>
</template>
<script>
import { el_table_merge_cell } from '@/utils/el-table-span-method'

export default {
  data() {
    return {
      table_data: [],//存放表格数据
      length_data: [],//存放相同数据的个数
    }
  },
  created() {
    this.get_list();
  },
  methods: {
    get_list() {
      let demo = [
        { name: '苹果', price: 20, time: '07:00:00', id: 1 },
        { name: '香蕉', price: 12, time: '08:00:00', id: 2 },
        { name: '苹果', price: 23, time: '09:00:00', id: 1 },
        { name: '西瓜', price: 30, time: '07:00:00', id: 3 },
        { name: '苹果', price: 11, time: '19:00:00', id: 1 },
        { name: '香蕉', price: 20, time: '10:00:00', id: 2 },
      ];
      // 合并相同的id
      let new_demo = demo.reduce((arr, cur) => {
        if (!arr[cur.id]) {
          arr[cur.id] = [];
        }
        arr[cur.id].push(cur);
        return arr;//注意返回
      }, {});

      this.table_data = Object.values(new_demo).flat();//数组扁平化,如[[1,2],3]变成一维数组[1,2,3]

      // 获取相同数据的长度,如果长度大于1,需要填充n-1个0
      let length_data = [];
      Object.values(new_demo).forEach(item => {
        length_data.push(item.length);
        if (item.length > 1) {
          length_data.push(...new Array(item.length - 1).fill(0));
        }
      })
      this.length_data = length_data;
    },
    // 合并数组
    object_merge({ row, column, rowIndex, columnIndex }) {
      return el_table_merge_cell({ row, column, rowIndex, columnIndex }, this.length_data)
    }
  }
}
</script>
相关推荐
Apifox14 分钟前
Apifox 11 月更新|AI 生成测试用例能力持续升级、JSON Body 自动补全、支持为响应组件添加描述和 Header
前端·后端·测试
木易士心15 分钟前
深入剖析:按下 F5 后,浏览器前端究竟发生了什么?
前端·javascript
在掘金8011017 分钟前
vue3中使用medium-zoom
前端·vue.js
xump39 分钟前
如何在DevTools选中调试一个实时交互才能显示的元素样式
前端·javascript·css
折翅嘀皇虫40 分钟前
fastdds.type_propagation 详解
java·服务器·前端
Front_Yue41 分钟前
深入探究跨域请求及其解决方案
前端·javascript
wordbaby42 分钟前
React Native 进阶实战:基于 Server-Driven UI 的动态表单架构设计
前端·react native·react.js
抱琴_43 分钟前
【Vue3】我用 Vue 封装了个 ECharts Hooks,同事看了直接拿去复用
前端·vue.js
风止何安啊1 小时前
JS 里的 “变量租房记”:闭包是咋把变量 “扣” 下来的?
前端·javascript·node.js
老华带你飞1 小时前
社区养老保障|智慧养老|基于springboot+小程序社区养老保障系统设计与实现(源码+数据库+文档)
java·数据库·vue.js·spring boot·小程序·毕设·社区养老保障