记录一下Bootstrap的DataTable,省得忘了。。。
项目中,有时候会遇到比较复杂的DataTable的头部需求,就像下图这样的。
表头(加粗字体的部分)包括三行,第三行就是对应得DataTable的字段,不需要分组的话,字段列会占三行,比如字段A、B、C;需要分组的话,表头的一、二行需要合并列,字段就只占一行或者两行,比如字段E-1、E-2、E-2-1。
下面来看看怎么用Bootstrap去构造一个这样的表格的。
1、需要在页面导入Bootstrap
<link href="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet">
<script src="https://cdn.staticfile.org/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/js/bootstrap.min.js"></script>
2、构造table
在table的thead添加3个tr标签,然后根据需求,看第一行是否有第二行(或第三行),选择是用rowspan还是colspan。如果第一行的一个column在第二、第三行没有包含多个字段,那么用rowspan="3";如果有包含多个字段用colspan="3"(里面的数字可换成N个,代表包含下一行的字段个数)。如果第二行的一个column在第三行中没有多个字段,那么用rowspan="2";如果有多个就参考第一行的情况。第三行就是列表的字段,如果该字段不包含复杂的头部结构,第一行既是第三行。
rowspan:表示合并N行
colspan:表示合并N个单元格
(我们这里是用一个三行表头举例子,其他行数的表头也差不多的做法)
详细请参考代码
<thead>
<tr>
<th rowspan="3">A</th>
<th rowspan="3">B</th>
<th rowspan="3">C</th>
<th rowspan="3">D</th>
<th colspan="3">E</th>
<th colspan="4">F</th>
<th rowspan="3">G</th>
<th colspan="12">H</th>
<th colspan="4">I</th>
<th rowspan="3">J</th>
</tr>
<tr>
<th rowspan="2">E-1</th>
<th rowspan="2">E-2</th>
<th rowspan="2">E-3</th>
<th rowspan="2">F-1</th>
<th colspan="3">F-2</th>
<th rowspan="2">H-1</th>
<th colspan="9">H-2</th>
<th rowspan="2">H-3</th>
<th rowspan="2">H-4</th>
<th rowspan="2">I-1</th>
<th rowspan="2">I-2</th>
<th rowspan="2">I-3</th>
<th rowspan="2">I-4</th>
</tr>
<tr>
<th>F-2-1</th>
<th>F-2-2</th>
<th>F-2-3</th>
<th>H-2-1</th>
<th>H-2-2</th>
<th>H-2-3</th>
<th>H-2-4</th>
<th>H-2-5</th>
<th>H-2-6</th>
<th>H-2-7</th>
<th>H-2-8</th>
<th>H-2-9</th>
</tr>
</thead>
3、加上一些必要的样式,让表格看起来顺眼一点。
这样一个拥有三行复合表头的数据表格就出来了
全部代码如下
@page
@model IndexModel
@{
ViewData["Title"] = "Home page";
}
<link href="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet">
<script src="https://cdn.staticfile.org/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdn.staticfile.org/twitter-bootstrap/3.3.7/js/bootstrap.min.js"></script>
<div>
<div class="tab-content" style="overflow:hidden;margin-top:20px;">
<table id="list" class="table table-bordered text-nowrap dataTableList2">
<thead>
<tr>
<th rowspan="3">A</th>
<th rowspan="3">B</th>
<th rowspan="3">C</th>
<th rowspan="3">D</th>
<th colspan="3" style="text-align:center;">E</th>
<th colspan="4" style="text-align: center;">F</th>
<th rowspan="3">G</th>
<th colspan="12" style="text-align: center;">H</th>
<th colspan="4" style="text-align: center;">I</th>
<th rowspan="3">J</th>
</tr>
<tr style="text-align:center;">
<th rowspan="2">E-1</th>
<th rowspan="2">E-2</th>
<th rowspan="2">E-3</th>
<th rowspan="2">F-1</th>
<th colspan="3" style="text-align:center;">F-2</th>
<th rowspan="2">H-1</th>
<th colspan="9" style="text-align:center;">H-2</th>
<th rowspan="2">H-3</th>
<th rowspan="2" style="text-align:center;">H-4</th>
<th rowspan="2">I-1</th>
<th rowspan="2">I-2</th>
<th rowspan="2">I-3</th>
<th rowspan="2" style="border-right: 1px solid rgb(222, 226, 230)">I-4</th>
</tr>
<tr style="text-align:center;">
<th>F-2-1</th>
<th>F-2-2</th>
<th>F-2-3</th>
<th>H-2-1</th>
<th>H-2-2</th>
<th>H-2-3</th>
<th>H-2-4</th>
<th>H-2-5</th>
<th>H-2-6</th>
<th>H-2-7</th>
<th>H-2-8</th>
<th style="border-right: 1px solid rgb(222, 226, 230)">H-2-9</th>
</tr>
</thead>
<tbody>
<tr>
<td>11</td>
<td>22</td>
<td>33</td>
<td>44</td>
<td>55</td>
<td>66</td>
<td>77</td>
<td>88</td>
<td>99</td>
<td>AA</td>
<td>SS</td>
<td>DD</td>
<td>FF</td>
<td>GG</td>
<td>HH</td>
<td>ZZ</td>
<td>XX</td>
<td>CC</td>
<td>VV</td>
<td>BB</td>
<td>NN</td>
<td>MM</td>
<td>JJ</td>
<td>KK</td>
<td>LL</td>
<td>QQ</td>
<td>WW</td>
<td>EE</td>
<td>RR</td>
</tr>
<tr>
<td>MM</td>
<td>JJ</td>
<td>KK</td>
<td>LL</td>
<td>QQ</td>
<td>WW</td>
<td>EE</td>
<td>RR</td>
<td>11</td>
<td>22</td>
<td>33</td>
<td>44</td>
<td>55</td>
<td>66</td>
<td>77</td>
<td>88</td>
<td>99</td>
<td>AA</td>
<td>SS</td>
<td>DD</td>
<td>FF</td>
<td>GG</td>
<td>HH</td>
<td>ZZ</td>
<td>XX</td>
<td>CC</td>
<td>VV</td>
<td>BB</td>
<td>NN</td>
</tr>
<tr>
<td>AA</td>
<td>SS</td>
<td>DD</td>
<td>FF</td>
<td>GG</td>
<td>HH</td>
<td>ZZ</td>
<td>XX</td>
<td>11</td>
<td>22</td>
<td>33</td>
<td>44</td>
<td>55</td>
<td>66</td>
<td>77</td>
<td>88</td>
<td>99</td>
<td>CC</td>
<td>VV</td>
<td>BB</td>
<td>NN</td>
<td>MM</td>
<td>JJ</td>
<td>KK</td>
<td>LL</td>
<td>QQ</td>
<td>WW</td>
<td>EE</td>
<td>RR</td>
</tr>
</tbody>
</table>
</div>
</div>
<script>
$(function () {
$("#list").wrap("<div style='overflow:auto; width:100%;position:relative;'></div>");
})
</script>
效果图如下