Element中table表格合並橫向單元格


element 的官方說明

通過給table傳入span-method方法可以實現合並行或列,方法的參數是一個對象,里面包含當前行row、當前列column、當前行號rowIndex、當前列號columnIndex四個屬性。該函數可以返回一個包含兩個元素的數組,第一個元素代表rowspan,第二個元素代表colspan。 也可以返回一個鍵名為rowspancolspan的對象。

 

 

官方代碼可以看出, 如果想要合並當前指定的單元格 需要指定合並的rowspan: 合並的行 colspan: 合並的列當直接設置為0的時候就不會顯示
因此當指定不同的rowspancolspan的時候就可以設定滿足條件的合並單元格
而且 objectSpanMethod 方法是table在渲染每一行的時候就會觸發
因此可以通過一個數組記錄每行的合並狀態

 1 objectSpanMethod({ row, column, rowIndex, columnIndex }) {
 2     if(columnIndex === 0) {
 3         if( rowIndex % 2 === 0 ) {
 4             return {
 5                   rowspan: 2,
 6                   colspan: 1
 7             };
 8         }
 9         else {
10             return {
11               rowspan: 0,
12               colspan: 0
13             };
14         }
15     }
16 },

那么,我么可以通過數組記錄每一行的合並狀態

 1 data() {
 2     return {
 3         id_array: [],
 4         id_pos: 0,
 5         tableData: []
 6     }
 7 },
 8 mounted() {
 9     this.id_init()
10 },
11 methods: {
12     id_init() {
13         this.id_array = []
14         this.id_pos = 0
15         for(let i = 0 ; i < this.tableData.length; i++) {
16             // 如果當 i == 0 說明數據是第一行, 需要重新賦值
17             if(i == 0) {
18                 // this.id_array.push(1) 說明這一行數據被顯示出來
19                 this.id_array.push(1)
20                 // this.id_pos = 0 重置當前的計數器
21                 this.id_pos = 0
22             }
23             // 說明不是從第一行開始遍歷的
24             else {
25                 // 判斷當前的指定數據是否和之前的指定數據值相同
26                 if(this.tableData[i].id == this.tableData[i-1].id) {
27                     // 如果相同就需要將 this.id_array 的數據自加
28                     this.id_array[this.id_pos] += 1
29                     // 同時需要將 this.id_array push一個0 表示下一行不用顯示
30                     this.id_array.push(0)
31                 }
32                 // 說明 當前的數據和上一行的指定數據不同
33                 else {
34                     // this.id_array.push(1) 說明當前一行的數據需要顯示
35                     this.id_array.push(1)
36                     // 重新給計數器賦值
37                     this.id_pos = i
38                 }
39             }
40         }
41     },
42     objectSpanMethod({ row, column, rowIndex, columnIndex }) {
43         // 用於給某一列的table判斷是否合並,下標0則是第一列,需要合並多個列可以寫多個條件
44         if(columnIndex === 0) {
45             // this.id_array[rowIndex] 取出當前存放行的合並狀態
46             const _row = this.id_array[rowIndex] 
47             // 判斷當前的 列是否需要顯示
48             const _col = _row > 0 ? 1 : 0
49             return {
50                 rowspan: _row,
51                 colspan: _col
52             }
53         }
54     }
55 }
1 代碼分析
2 首先 id_init 方法用於獲取當前傳遞的數據中 有哪些是需要合並的數據
3 this.id_array = [] 用來存放需要合並的單元格的數據
4 打印結果 [2, 0, 8, 0, 0, 0, 0, 0, 0, 0]
5 數組中的0 代表當前單元格是不需要顯示, 已經被合並的單元格
6 數組中的數字代表當前的數據需要合並幾個單元格
7 this.id_pos = 0 用來存放當前需要合並單元格的索引
8 當數據需要合並單元格的時候, 保存當前數據的索引, 一直到不滿足合並單元格時的條件, 之后再記錄新的數據的索引
if(i == 0) {
    // this.id_array.push(1) 說明這一行數據被顯示出來
    this.id_array.push(1)
    // this.id_pos = 0 重置當前的計數器
    this.id_pos = 0
}
1 當i == 0 說明當前的索引為 0 需要設置默認的顯示數據
2 this.id_array.push(1) 就是用於設置默認第一行的顯示
3 this.id_pos = 0 用來重置當前項的位置

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM