0
点赞
收藏
分享

微信扫一扫

狮子鱼社区团购小程序v18.1独立全开源版+小程序前端

胡桑_b06e 2023-09-18 阅读 22
vueelementui
/**
 * 合并相同数据,导出合并列所需的方法(只适合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'])
举报

相关推荐

0 条评论