bootstrap-table实现表头固定以及列固定的⽅法⽰例
之前使⽤bootstrap写了⼀个报表表格,最近突然到我,说让我看看能不能将表格的表头和第⼀列进⾏固定,这样的话⽅便查看数据,于是,我开始了苦逼的研究起来,毕竟我是个后端啊,对于前端的样式问题,特别是⼩功能,烦的⼀批
这⾥就记录下我的研究成果
⼀:引⼊js和css
<!-- 引⼊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" rel="external nofollow" >
<script src="./js/bootstrap.min.js" ></script>
<!-- 固定表头所需的js和css(bootstrap-table) -->
<link rel="stylesheet" type="text/css" href="./css/bootstrap-table.min.css" rel="external nofollow" >
<script src="./js/bootstrap-table.min.js"></script>
<!-- 固定列所需的js和css(bootstrap-table-fixed-columns) -->为什么使用bootstrap?
<link rel="stylesheet" type="text/css" href="./css/bootstrap-table-fixed-columns.css" rel="external nofollow" >
<script src="./js/bootstrap-table-fixed-columns.js"></script>
这⾥注意:
引⼊jquery时,不要引⼊jquery2.0.0(包括2.0.0)版本以下,如果你引⼊了2.0.0版本以下的jquery的话,当你编写完代码之后,在控制台会出现如下错误:
⼆:编写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"表⽰
设置表格的⾼度,⽤于配置固定表头。由于我这⾥编写的表格数据较少,所以展⽰出来的数据可能不会出现滑轮,看不出来固定表头现象,你可以向表格中添加多⼀点数据就可以了
三:固定列
<script>
$(function(){
//#table表⽰的是上⾯table表格中的id
$("#table").bootstrapTable('destroy').bootstrapTable({
fixedColumns: true,
fixedNumber: 1 //固定列数
});
})
</script>
四:当浏览器窗⼝变化时,表头与表格不对齐解决:
<script>
$(function(){
$('#table').bootstrapTable();
$(window).resize(function () {
$('#table').bootstrapTable('resetView');
});
})
</script>
五:初次展⽰时表头和表格数据不对齐解决(个⼈使⽤的⽅法,⽅法有点傻)
进过上⾯的过程我们已经实现了表格的表格和列固定功能了,于是我便开始将报表修改起来,开始修
改起来⼗分的轻松,没有问题,但是,当我修改到⼀个报表的时候发现,开始的时候,表头和数据之间就发⽣了不对齐现象:
于是我开始在⽹上搜索起来,但是⽹上搜索的答案根本解决不了,例如:
到bootstrap-table的源码中
if (this.options.showHeader && this.options.height) {
this.$tableHeader.show();
//注释掉下⾯两⾏取消表头初始化解决表头和内容不对齐问题
//setHeader();
//padding += this.$header.outerHeight();
}
不知道写这个的兄弟有没有⾃⼰测试过,反正我注释了之后,确实表头和数据对齐了,但是表头固定功能消失了,表头和数据不对齐的原因就是因为你设置了固定表头影响的,你这样将表头固定功能去掉了,那么我直接将table标签中的data-
height="200"去掉不久⾏了吗,为什么还要改源码呢?
于是我⾃⼰开始研究起来
最后我使⽤审查元素到错位的表头位置,发现这样⼀段代码
<div class="fht-cell" ></div>
这⾥将宽度设置为了146但是我的数据宽度只有120,这才造成了错位,
然后我到bootstrap-table源码设置div的class为fht-cell宽度的代码位置
虽然我到了问题所在,但是源码哪⾥出问题了,我还是不清楚,有知道的伙伴,欢迎告诉我答案
既然我不知道源码出问题出在哪,那么我就使⽤⼗分傻的⽅法,直接设置class为fht-cell的宽度,将之前宽度为146的覆盖.fht-cell{width:120px!important;}
然后打开观看,错误问题解决了
以上就是本⽂的全部内容,希望对⼤家的学习有所帮助,也希望⼤家多多⽀持。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。