Bootstrap DataTable 表头设计

记录一下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>

效果图如下 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

郑小晨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值