element-uiの公式ウェブサイトでの行のマージの例は、行番号に基づいてマージすることです。これは、通常、テーブル内のデータが動的に生成されるため、いくつかの変更が必要なため、明らかに日常の開発ニーズを満たしていません。まず、公式Webサイトインスタンスの各パラメーターの意味を解釈しましょう。
objectSpanMethod({
row, column, rowIndex, columnIndex }) {
if (columnIndex === 0) {
//用于设置要合并的列
if (rowIndex % 2 === 0) {
//用于设置合并开始的行号
return {
rowspan: 2, //合并的行数
colspan: 1 //合并的列数,设为0则直接不显示
};
} else {
return {
rowspan: 0,
colspan: 0
};
}
}
}
画像の例:
IDデータに基づいて列を動的にマージします。
機能コード:
データソースは判定条件に従ってソートする必要があります。ここでは例としてidを取り上げます。
var Main = {
data() {
return {
tableData: [
{
id: '12987122',
name: '王小虎',
amount1: '234',
amount2: '3.2',
amount3: 10
},
{
id: '12987122',
name: '王小虎',
amount1: '123',
amount2: '12',
amount3: 10
}, {
id: '12987123',
name: '王小虎',
amount1: '165',
amount2: '4.43',
amount3: 12
}, {
id: '12987124',
name: '王小虎',
amount1: '324',
amount2: '1.9',
amount3: 9
},
{
id: '12987124',
name: '王小虎',
amount1: '324',
amount2: '1.9',
amount3: 9
},
{
id: '12987124',
name: '王小虎',
amount1: '324',
amount2: '1.9',
amount3: 9
},{
id: '12987125',
name: '王小虎',
amount1: '621',
amount2: '2.2',
amount3: 17
}, {
id: '12987126',
name: '王小虎',
amount1: '539',
amount2: '4.1',
amount3: 15
}
],
merge:[], //存放需要合并的行
pos:'' //需要合并行下标
};
},
created() {
this.getSpanArr(this.tableData)
},
methods: {
getSpanArr(data) {
for (var i = 0; i < data.length; i++) {
if (i === 0) {
this.merge.push(1);
this.pos = 0
} else {
// 判断当前元素与上一个元素是否相同
//根据相同id进行合并,根据需要可进行修改
if (data[i].id === data[i - 1].id) {
this.merge[this.pos] += 1;
this.merge.push(0);
} else {
this.merge.push(1);
this.pos = i;
}
}
}
},
SpanCellMerge({
row, column, rowIndex, columnIndex }) {
if (columnIndex === 0) {
const _row = this.merge[rowIndex];
const _col = _row > 0 ? 1 : 0;
return {
rowspan: _row,
colspan: _col
}
}
},
}
};
var Ctor = Vue.extend(Main)
new Ctor().$mount('#app')
dataはバックグラウンドから取得するデータであり、通常は配列です。mergeは空の配列であり、各行のマージされたレコードの数を格納するために使用されます
。posはマージのインデックスです。上記のコードは次のことを意味します:それが最初のレコード(インデックスが0)の場合、配列に1を追加し、インデックスの位置を設定します。
最初のレコードでない場合は、前のレコードと等しいかどうかを判断します。、次に要素0を追加してマージし、前の要素+1はマージされた行の数+1を意味し、次に往復してすべての行のマージされた数を取得します。0は行が表示されないことを意味します。
ページコード:
<template>
<div>
<el-table
:data="tableData"
:span-method="SpanCellMerge"
border
style="width: 100%; margin-top: 20px">
<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="amount1"
label="数值 1(元)">
</el-table-column>
<el-table-column
prop="amount2"
label="数值 2(元)">
</el-table-column>
<el-table-column
prop="amount3"
label="数值 3(元)">
</el-table-column>
</el-table>
</div>
</template>