# 第二章:自定义表格渲染

# 概述

关于原生表格合并的处理方法有很多种,目前我对这种数据格式进行处理

let data = [{
   columns: ['a1', 'b1', 'c1'],
   colSpan: [1, 1, 1],
   rowSpan: [2, 1, 1]
}, {
   columns: ['a2', 'b2', 'c2'],
   colSpan: [1, 1, 1],
   rowSpan: [0, 2, 1]
}, {
   columns: ['a3', 'b3', 'c3'],
   colSpan: [1, 1, 1],
   rowSpan: [2, 0, 1]
}, {
   columns: ['a4', 'b4', 'c4'],
   colSpan: [1, 2, 0],
   rowSpan: [0, 1, 1]
}]

let table = document.createElement('table')
table.border='border'
let tbody = ''
for (let i = 0; i < data.length; i++) {
   tbody += `<tr>`
   for (let j = 0; j < data[i].columns.length; j++) {
       if(data[i].rowSpan[j]&&data[i].colSpan[j]){
         tbody += `<td  rowspan="${data[i].rowSpan[j]}" colspan="${data[i].colSpan[j]}">${data[i].columns[j]}</td>`
       }
   }
   tbody += `</tr>`
}
table.innerHTML = tbody
document.body.append(table)
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
Last Updated: 1/17/2022, 6:02:56 PM