• element plus表格合并行


    1. /**
    2. * 合并相同数据,导出合并列所需的方法(只适合el-table)
    3. */
    4. export function getRowSpanMethod(data, rowSpanArray) {
    5. /**
    6. * 要合并列的数据
    7. */
    8. const rowSpanNumObject = {};
    9. //初始化 rowSpanNumObject
    10. rowSpanArray.map((item) => {
    11. rowSpanNumObject[item] = new Array(data.length).fill(1, 0, 1).fill(0, 1);
    12. rowSpanNumObject[`${item}-index`] = 0;
    13. });
    14. //计算相关的合并信息
    15. for (let i = 1; i < data.length; i++) {
    16. rowSpanArray.map((key) => {
    17. const index = rowSpanNumObject[`${key}-index`];
    18. if (data[i][key] === data[i - 1][key]) {
    19. rowSpanNumObject[key][index]++;
    20. } else {
    21. rowSpanNumObject[`${key}-index`] = i;
    22. rowSpanNumObject[key][i] = 1;
    23. }
    24. });
    25. }
    26. //提供合并的方法并导出
    27. const spanMethod = function ({ row, column, rowIndex, columnIndex }) {
    28. if (rowSpanArray.includes(column["property"])) {
    29. const rowspan = rowSpanNumObject[column["property"]][rowIndex];
    30. if (rowspan > 0) {
    31. return { rowspan: rowspan, colspan: 1 };
    32. }
    33. return { rowspan: 0, colspan: 0 };
    34. }
    35. return { rowspan: 1, colspan: 1 };
    36. };
    37. return spanMethod;
    38. }

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

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

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

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

    具体长这样

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

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

  • 相关阅读:
    Hutool工具包中BeanUtil的使用
    MySQL8(增删改)
    神经网络算法基本介绍,简单神经网络算法原理
    Vue Router的介绍
    知识付费的8个小问题
    白帽SEO与黑帽SEO的区别
    安装淘宝镜像cnpm
    win10怎么设置不睡眠熄屏?win10设置永不睡眠的方法
    anzo capital昂首资本:MT4和MT5 EA测试的主要区别
    leetcode 线程题 1114. 按序打印
  • 原文地址:https://blog.csdn.net/qq_43378240/article/details/132811323