bootstrap-table实现表头固定以及列固定的方法示例

作者:huaweichenai 时间:2024-04-29 13:13:19 

之前使用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) -->
<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>

query下载地址:https://www.aspxhome.com/zt/jquerydown.htm
bootstrap下载地址:http://www.bootcss.com/
bootstrap-table下载地址:https://bootstrap-table.com
bootstrap-table-fixed-columns下载地址:https://github.com/wenzhixin/bootstrap-table-fixed-columns

这里注意:

引入jquery时,不要引入jquery2.0.0(包括2.0.0)版本以下,如果你引入了2.0.0版本以下的jquery的话,当你编写完代码之后,在控制台会出现如下错误:

bootstrap-table实现表头固定以及列固定的方法示例

二:编写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实现表头固定以及列固定的方法示例

于是我开始在网上搜索起来,但是网上搜索的答案根本解决不了,例如:

找到bootstrap-table的源码中


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宽度的代码位置

bootstrap-table实现表头固定以及列固定的方法示例

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

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


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

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

来源:https://segmentfault.com/a/1190000018411239

标签:bootstrap-table,表头固定,列固定
0
投稿

猜你喜欢

  • Go语言使用sort包对任意类型元素的集合进行排序的方法

    2023-09-02 03:55:18
  • Python学习笔记之图片人脸检测识别实例教程

    2021-12-03 06:17:28
  • php实现HTML实体编号与非ASCII字符串相互转换类实例

    2023-11-15 06:12:14
  • 浅析JavaScript对象转换成原始值

    2023-08-05 02:09:11
  • jquery实现不同大小浏览器使用不同的css样式表的方法

    2024-04-10 10:34:53
  • Django中自定义查询对象的具体使用

    2021-05-26 03:11:18
  • ORACLE学习笔记-新建用户及建表篇

    2024-01-18 15:33:46
  • Python遍历文件夹和读写文件的实现方法

    2023-07-08 06:02:56
  • Python多进程编程multiprocessing代码实例

    2022-11-20 20:25:51
  • 网页设计的色彩思考

    2007-10-19 13:30:00
  • Python光学仿真之对光的干涉理解学习

    2021-05-24 04:47:52
  • select下拉菜单实现二级联动效果

    2023-05-22 22:30:32
  • Django的get_absolute_url方法的使用

    2023-05-28 02:38:14
  • 基于PyQT实现区分左键双击和单击

    2022-10-30 01:58:47
  • 详细讲解如何删除Access数据库中的空记录

    2008-11-28 14:58:00
  • 跟老齐学Python之有容乃大的list(4)

    2023-03-13 21:53:17
  • python数据库编程 Mysql实现通讯录

    2024-01-24 17:53:11
  • Python破解excel进入密码的过程详解

    2021-06-14 03:06:25
  • 解决python 读取excel时 日期变成数字并加.0的问题

    2021-07-11 18:53:41
  • SQL语句执行超时引发网站首页访问故障问题

    2024-01-29 01:33:27
  • asp之家 网络编程 m.aspxhome.com