/**
* 合并相同数据,导出合并列所需的方法(只适合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'])