element plus表格合并行

news/2024/7/10 1:58:18 标签: vue, elementui
/**
 * 合并相同数据,导出合并列所需的方法(只适合el-table)
 */
export function getRowSpanMethod(data, rowSpanArray) {
  /**
   * 要合并列的数据
   */
  const rowSpanNumObject = {};

  //初始化 rowSpanNumObject
  rowSpanArray.map((item) => {
    rowSpanNumObject[item] = new Array(data.length).fill(1, 0, 1).fill(0, 1);
    rowSpanNumObject[`${item}-index`] = 0;
  });
  //计算相关的合并信息
  for (let i = 1; i < data.length; i++) {
    rowSpanArray.map((key) => {
      const index = rowSpanNumObject[`${key}-index`];
      if (data[i][key] === data[i - 1][key]) {
        rowSpanNumObject[key][index]++;
      } else {
        rowSpanNumObject[`${key}-index`] = i;
        rowSpanNumObject[key][i] = 1;
      }
    });
  }

  //提供合并的方法并导出
  const spanMethod = function ({ row, column, rowIndex, columnIndex }) {
    if (rowSpanArray.includes(column["property"])) {
      const rowspan = rowSpanNumObject[column["property"]][rowIndex];
      if (rowspan > 0) {
        return { rowspan: rowspan, colspan: 1 };
      }
      return { rowspan: 0, colspan: 0 };
    }
    return { rowspan: 1, colspan: 1 };
  };

  return spanMethod;
}

新建一个工具js复制上面代码,然后引用

import { getRowSpanMethod } from "@/utils/use_span_method.js";

在el-table中设置方法,核心就是:span-method="spanMethod",span-method是element-plus中的合并表格的方法,但是合并的方法有点简陋,是根据奇偶分的,不满足需求,这里我是要将同一个组的“合计请款量(月)”合并

<el-table :data="tableData.arr" :span-method="spanMethod" border style="width: 100%">
      <el-table-column prop="area" label="区域" />
      <el-table-column prop="group" label="设备分组(售楼部)" />
      <el-table-column prop="name" label="设备名称" />
      <el-table-column prop="number" label="请款数量(月)" />
      <el-table-column prop="numberAll" label="合计请款量(月)" />
      <el-table-column prop="time" label="接入时间" />
    </el-table>

具体长这样

最后调用方法,并传入参数getRowSpanMethod(对象数组,[需要合并的字段])

const spanMethod = getRowSpanMethod(tableData.arr,['numberAll'])


http://www.niftyadmin.cn/n/5018717.html

相关文章

天津大数据培训学校 大数据可从事的行业

大数据行业近年来呈现出爆炸式的增长态势&#xff0c;各行各业都越来越依赖数据来指导业务决策和创新发展&#xff0c;因此&#xff0c;大数据专业人才的需求也随之增长。这种行业需求的增长为大数据就业提供了良好的机会&#xff0c;尤其是对于具备相关技能和知识的人来说。 …

【Unity】Unity坑的集锦之RenderTexture打包黑屏

问题&#xff1a;Camera Output Texture设置RenderTexture后&#xff0c;打包用来Save PNG&#xff0c;黑屏 如果你打AB 包&#xff0c;然后是相机的OutputTexture是拖拽的话&#xff0c;记得将包一起打入 或者你可以代码赋值 Camera.targetTexture await Loader.LoadAsset&l…

办公:批量修改sheet名称

1&#xff0c;在已有工作簿中&#xff0c;在最后位置新增工作表&#xff08;sheet&#xff09; 2&#xff0c;将要改的sheet名称在新建工作表中第一列按顺序填充 3&#xff0c;在键盘上按住AltF11&#xff0c;打开VBA窗口 4&#xff0c;依次点击工具栏中的【插入】——【模块】…

如何用echarts画一个好看的饼图

前言 最近有个需求&#xff0c;需要绘制一个饼图&#xff0c;为此我根据这次需求来整理了一下关于 echarts 饼图绘制的一些知识点&#xff0c;在这次需求中我需要用到的属性我会详细讲解&#xff0c;其他的属性我会粗略地说一下&#xff08;并加入其他博主的文章的跳转&#x…

Nuxtjs在linux环境下部署笔记

问题&#xff1a;Nuxtjs在linux环境下部署&#xff0c;ip端口无法访问&#xff1f; 一 、解决方案 方案一&#xff1a;修改package.json文件 添加如下配置&#xff1a; "config": {"nuxt": {"host": "0.0.0.0","port":…

信息系统工程监理课程内容

第一部分 卢学哲专家1-5天内容 Day01 1 信息监理的发展史 发展史 背景 对数字敏感 时间&#xff1a;是否有交叉 重叠 成本&#xff1a;各种相关费用 工程量&#xff1a;硬件软件的数量&#xff0c;工作量的大小 1988年出现的信息监理2 信息监理工程师的职业素养 公平 公…

怎样做思维导图?教你这样轻松制作

怎样做思维导图&#xff1f;思维导图是一种非常有用的工具&#xff0c;它可以帮助你更好地组织和展示你的想法。无论是个人使用还是团队协作&#xff0c;思维导图都是一个非常好的选择。在制作思维导图时&#xff0c;有很多工具可以使用&#xff0c;那么今天就给大家来介绍一下…

记录socket的使用 | TCP/IP协议下服务器与客户端之间传送数据 | java学习笔记

谨以此篇&#xff0c;记录TCP编程&#xff0c;方便日后查阅笔记 注意&#xff1a;用BufferedWriter write完后&#xff0c;一定要flush&#xff1b;否则字符不会进入流中。去看源码可知&#xff1a;真正将字符写入的不是write()&#xff0c;而是flush()。 服务器端代码&#…