element plus表格合并行

/**
 * 合并相同数据,导出合并列所需的方法(只适合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中的合并表格的方法,但是合并的方法有点简陋,是根据奇偶分的,不满足需求,这里我是要将同一个组的“合计请款量(月)”合并


      
      
      
      
      
      
    

具体长这样

element plus表格合并行_第1张图片

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

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

你可能感兴趣的:(vue,elementui)