# 嵌套数据合并单元格
往往后端传给前端的数据是下面的格式,含有嵌套的数组 这种格式的数据该怎么合并单元格呢?
tableData: [
{
id: 1,
name: "name-1",
data: [{ amount: 100 }, { amount: 200 }, { amount: 300 }]
},
{ id: 2, name: "name-2", data: [{ amount: 1002 }, { amount: 2002 }] },
{
id: 3,
name: "name-3",
data: [
{ amount: 1003 },
{ amount: 2003 },
{ amount: 3003 },
{ amount: 3004 }
]
}
]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
# 效果图

# 实现思路
- 1、首先进行数据格式转换,转换成符合官网的数据格式
- 2、生成合并信息的数组(那些列或者行要合并,哪些列或者行要隐藏)
- 3、使用span-method方法
# 完整代码
<template>
<div>
<el-table :data="tableData" :span-method="objectSpanMethod" border>
<el-table-column prop="id" label="ID" width="180"></el-table-column>
<el-table-column prop="name" label="姓名"></el-table-column>
<el-table-column prop="amount" sortable label="数值"></el-table-column>
</el-table>
</div>
</template>
<script>
export default {
data() {
return {
rowspan: "",
tableData: [
{
id: 1,
name: "星城哈哈-1",
data: [{ amount: 100 }, { amount: 200 }, { amount: 300 }]
},
{ id: 2, name: "星城哈哈-2", data: [{ amount: 1002 }, { amount: 2002 }] },
{
id: 3,
name: "星城哈哈-3",
data: [
{ amount: 1003 },
{ amount: 2003 },
{ amount: 3003 },
{ amount: 3004 }
]
},
]
};
},
methods: {
objectSpanMethod({ row, column, rowIndex, columnIndex }) {
if ([0, 1].includes(columnIndex)) {
const _row = this.rowspan[rowIndex];
const _col = _row > 0 ? 1 : 0; // 如果这一行隐藏了,这列也隐藏
return {
rowspan: _row,
colspan: _col
};
}
},
convertTableData() {
let data = this.tableData;
let arr = [];
let rowspan = [];
data.forEach(item => {
//debugger
for (let i = 0; i < item.data.length; i++) {
let rdata = {
...item,
...item.data[i]
};
debugger
rdata.combineNum = item.data.length;
delete rdata.data;
// rdata={ id: 1,name: "name-1",amount: 1003}
arr.push(rdata);
// 生成合并信息的数组 [3, 0, 0, 2, 0, 4, 0, 0, 0] 其中的0代表隐藏
if (i == 0) {
rowspan.push(item.data.length);
} else {
rowspan.push(0);
}
}
});
//console.log(arr)
this.tableData = arr;
console.log(this.tableData);
console.log(rowspan);
this.rowspan = rowspan;
}
},
created() {
this.convertTableData();
}
};
</script>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83