iView(View UI) Table行合并

文档

表格Table 行/列合并

4.0.0 设置属性 span-method 可以指定合并行或列的算法。

该方法参数为 4 个对象:

  • row: 当前行
  • column: 当前列
  • rowIndex: 当前行索引
  • columnIndex: 当前列索引

该函数可以返回一个包含两个元素的数组,第一个元素代表 rowspan,第二个元素代表 colspan。 也可以返回一个键名为 rowspancolspan 的对象。


但官方文档并没有说明rowspancolspan是怎么回事,通过对官方的示例观察以及验证,得出以下结论:

  • rowspan = 0 隐藏该行
  • rowspan = 1 显示该行
  • rowspan > 1 涉及合并的行数或者说合并rowspan - 1的行数,需要注意的一点,它是从该行往下合并。比如rowspan为3,则从这一行开始算,接下来三行会进行合并。

colspan没验证过,但规则应该是一致的,把行换成列,往下合并换成往右合并。

“通用”的行合并实现

  • 基于文档 表格Table 行/列合并 的示例代码修改
  • 只适用于数据格式为“常见”的对象数组
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    [
    {
    "name": "Jim",
    "age": 18,
    "address": "Sydney",
    "date": "2016-10-03"
    },
    {
    "name": "Jim",
    "age": 24,
    "address": "London",
    "date": "2016-10-01"
    }
    ]
  • 想要忽略某一列的行合并,把 columns 的 key 对应 push 入 ignoreMergeRow 数组即可
  • 其他请查看代码注释

效果

忽略name列的行合并

代码

代码仅供参考,如有更优雅的实现方式,请不吝赐教

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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
<template>
<div>
<Table :columns="columns14" :data="data5" border :span-method="handleSpan"></Table>
</div>
</template>

<script>
export default {
data() {
return {
columns14: [{
title: 'Date',
key: 'date'
},
{
title: 'Name',
key: 'name'
},
{
title: 'Age',
key: 'age'
},
{
title: 'Address',
key: 'address'
}
],
data5: [],
ignoreMergeRow:[]
}
},
methods: {
handleMergeRow(data) {
let ret = JSON.parse(JSON.stringify(data));
let collection = {};
let preIndex = -1;
for (let i in ret) {
// item = {
// "name": "Jim",
// "age": 18,
// "address": "Sydney",
// "date": "2016-10-03"
// }
let item = ret[i];
item.source = {};
for (let key in item) {
if (key == "source") {
continue;
}
// 记录每个key
// collection = {
// "name": {}
// }
if (!collection[key]) {
collection[key] = {};
}
// 首项或者该项此列不等于上一项此列
if (preIndex == -1 || ret[preIndex][key] != item[key]) {
// 记录每个key对应的所有值以及其起始索引和出现次数
// collection = {
// "name": {
// "Jim#0": {
// "firstIndex": 0,
// "count": 1
// }
// }
// }
collection[key][`${item[key]}#${i}`] = {
firstIndex: i,
count: 1
};
// 标注该列的起源index
item.source[key] = i;
} else {
// 通过上一项找到起源index
let source = ret[preIndex].source[key];
item.source[key] = source;
// 合并该列的行数加1
collection[key][`${item[key]}#${source}`].count += 1;
}
}
preIndex = i;
}
console.log(collection)
for (let key in collection) {
// items = {
// "Jim#0": {
// "firstIndex": "0",
// "count": 3
// },
// "Jon#3": {
// "firstIndex": "3",
// "count": 1
// }
// }
let items = collection[key];
for (let itemkey in items) {
// value = {
// "firstIndex": "0",
// "count": 3
// }
let value = items[itemkey];
// 根据记录的起始索引设置该项的mergeRow
// {
// "name": "Jim",
// "age": 18,
// "address": "Sydney",
// "date": "2016-10-03",
// "mergeRow": {
// "address": 1,
// "age": 1,
// "date": 1,
// "name": 3
// }
// }
if (!ret[value.firstIndex].mergeRow) {
ret[value.firstIndex].mergeRow = {};
}
ret[value.firstIndex].mergeRow[key] = value.count;
}
}
console.log(ret)
return ret;
},
handleSpan({
row,
column,
rowIndex,
columnIndex
}) {
if (row.mergeRow) {
// 忽略合并该行此列
if (this.ignoreMergeRow && this.ignoreMergeRow.indexOf(column.key) >= 0) {
return {
rowspan: 1,
colspan: 1
};
}
// 存在此列的key,则该行此列应显示,向下合并此列的几行(包括自己)则取决于其值
if (row.mergeRow[column.key]) {
return {
rowspan: row.mergeRow[column.key],
colspan: 1
};
} else {
// 说明该行此列应被在此之上的行合并,rowspan和colspan设置为0,不予显示
return {
rowspan: 0,
colspan: 0
};
}
}
},
},
mounted() {
let data = [{
name: 'Jim',
age: 18,
address: 'Sydney',
date: '2016-10-03'
},
{
name: 'Jim',
age: 24,
address: 'London',
date: '2016-10-01'
},
{
name: 'Jim',
age: 30,
address: 'Sydney',
date: '2016-10-01'
},
{
name: 'Jon',
age: 26,
address: 'Sydney',
date: '2016-10-04'
}
];
this.data5 = this.handleMergeRow(data);
}
}
</script>

<style>

</style>

作者

DullSword

发布于

2020-11-26

更新于

2024-12-13

许可协议

评论