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>
相关推荐
琴~~6 分钟前
ant-design-vue中table某一列进行合并
前端·javascript·vue.js
sunly_42 分钟前
Flutter:flutter_screenutil屏幕适配
前端·javascript·flutter
俸涛努力学前端1 小时前
ajax (一)
开发语言·前端·javascript·笔记·ajax
凌虚(失业了求个工作)1 小时前
Web 端语音对话 AI 示例:使用 Whisper 和 llama.cpp 构建语音聊天机器人
前端·人工智能·python·whisper·llama
信息化未来2 小时前
odoo17 档案管理之翻译2
java·服务器·前端
川石课堂软件测试2 小时前
UI自动化测试|web端元素获取&元素等待实践
开发语言·前端·功能测试·算法·ui
糯米w2 小时前
【前端】excel文件对比
前端·javascript·excel
Ace_31750887762 小时前
微店商品详情接口技术实现详解及代码示例
前端
南城巷陌2 小时前
node.js中实现router模块化管理
前端·javascript·node.js·express.router
new Vue()2 小时前
ES6中Promise的使用场景
开发语言·前端·javascript