bootstrap-table实现表头固定以及列固定

以前使用bootstrap写了一个报表表格,最近忽然找到我,说让我看看能不能将表格的表头和第一列进行固定,这样的话方便查看数据,因而,我开始了苦逼的研究起来,毕竟我是个后端啊,对于前端的样式问题,特别是小功能,烦的一批
这里就记录下个人研究成果
一:引入js和cssjavascript

<!-- 引入jquery -->
<script type="text/javascript" src="./js/jquery-3.3.1.min.js"></script>
<!-- 引入bootstrap的js和css文件 -->
<link rel="stylesheet" href="./css/bootstrap.min.css" >
<script src="./js/bootstrap.min.js" ></script>
<!-- 固定表头所需的js和css(bootstrap-table) -->
<link rel="stylesheet" type="text/css" href="./css/bootstrap-table.min.css">
<script src="./js/bootstrap-table.min.js"></script>
<!-- 固定列所需的js和css(bootstrap-table-fixed-columns) -->
<link rel="stylesheet" type="text/css" href="./css/bootstrap-table-fixed-columns.css">
<script src="./js/bootstrap-table-fixed-columns.js"></script>

query下载地址:http://www.jq22.com/jquery-in...
bootstrap下载地址:http://www.bootcss.com/
bootstrap-table下载地址:https://bootstrap-table.com/
bootstrap-table-fixed-columns下载地址:https://github.com/wenzhixin/...
这里注意:
引入jquery时,不要引入jquery2.0.0(包括2.0.0)版本如下,若是你引入了2.0.0版本如下的jquery的话,当你编写完代码以后,在控制台会出现以下错误:css

clipboard.png
二:编写table表格(固定表头)前端

<table  class="table table-bordered" id="table" data-toggle="table" data-height="200">
<thead>
<tr>
        <th>表头一</th>
        <th>表头二</th>
        <th>表头三</th>
        <th>表头四</th>
    </tr>
</thead>
<tbody>
<tr>
        <td>1</td>
        <td>2</td>
        <td>3</td>
        <td>4</td>
    </tr>
    <tr>
<td>1</td>
<td>2</td>
<td>3</td>
<td>4</td>
    </tr>
</tbody>
</table>

上面代码中的table标签中的
data-toggle="table"表示的是启用bootstrap表格,
data-height="200"表示设置表格的高度,用于配置固定表头
因为我这里编写的表格数据较少,因此展现出来的数据可能不会出现滑轮,看不出来固定表头现象,你能够向表格中添加多一点数据就能够了
三:固定列java

<script>
$(function(){
 //#table表示的是上面table表格中的id
 $("#table").bootstrapTable('destroy').bootstrapTable({
        fixedColumns: true, 
        fixedNumber: 1 //固定列数
    });
})
</script>

四:当浏览器窗口变化时,表头与表格不对齐解决:jquery

<script>
$(function(){
$('#table').bootstrapTable();
    $(window).resize(function () {
        $('#table').bootstrapTable('resetView');
    });
})
</script>

五:初次展现时表头和表格数据不对齐解决(我的使用的方法,方法有点傻)
进过上面的过程咱们已经实现了表格的表格和列固定功能了,因而我便开始将报表修改起来,开始修改起来十分的轻松,没有问题,可是,当我修改到一个报表的时候发现,开始的时候,表头和数据之间就发生了不对齐现象:git

clipboard.png
因而我开始在网上搜索起来,可是网上搜索的答案根本解决不了,例如:github

找到bootstrap-table的源码中bootstrap

if (this.options.showHeader && this.options.height) {
            this.$tableHeader.show();
            //注释掉下面两行 取消表头初始化解决表头和内容不对齐问题
            //this.resetHeader();
            //padding += this.$header.outerHeight();
}

不知道写这个的兄弟有没有本身测试过,反正我注释了以后,确实表头和数据对齐了,可是表头固定功能消失了,表头和数据不对齐的缘由就是由于你设置了固定表头影响的,你这样将表头固定功能去掉了,那么我直接将table标签中的data-height="200"去掉不久行了吗,为何还要改源码呢?后端

因而我本身开始研究起来浏览器

最后我使用审查元素找到错位的表头位置,发现这样一段代码

<div class="fht-cell" style="width: 146px;"></div>

这里将宽度设置为了146可是个人数据宽度只有120,这才形成了错位,

而后我找到bootstrap-table源码设置div的class为fht-cell宽度的代码位置

clipboard.png
虽然我找到了问题所在,可是源码哪里出问题了,我仍是不清楚,有知道的伙伴,欢迎告诉我答案

既然我不知道源码出问题出在哪,那么我就使用十分傻的方法,直接设置class为fht-cell的宽度,将以前宽度为146的覆盖

.fht-cell{width:120px!important;}

而后打开观看,错误问题解决了!!!

相关文章
相关标签/搜索