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

news/2024/7/19 15:26:24 标签: js, bootstrap

之前使用bootstrap写了一个报表表格,最近突然找到我,说让我看看能不能将表格的表头和第一列进行固定,这样的话方便查看数据,于是,我开始了苦逼的研究起来,毕竟我是个后端啊,对于前端的样式问题,特别是小功能,烦的一批

这里就记录下我的研究成果

一:引入js和css

<!-- 引入jquery -->
<script type="text/javascript" src="./js/jquery-3.3.1.min.js"></script>
<!-- 引入bootstrapjs和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>

jquery下载地址:http://www.jq22.com/jquery-info122

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的话,当你编写完代码之后,在控制台会出现如下错误:

image.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"表示设置表格的高度,用于配置固定表头

由于我这里编写的表格数据较少,所以展示出来的数据可能不会出现滑轮,看不出来固定表头现象,你可以向表格中添加多一点数据就可以了

三:固定列

<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>

五:初次展示时表头和表格数据不对齐解决(个人使用的方法,方法有点傻)

进过上面的过程我们已经实现了表格的表格和列固定功能了,于是我便开始将报表修改起来,开始修改起来十分的轻松,没有问题,但是,当我修改到一个报表的时候发现,开始的时候,表头和数据之间就发生了不对齐现象:

image.png

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

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

image.png

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

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

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

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


http://www.niftyadmin.cn/n/1583753.html

相关文章

JPA JPQL 查询、排序

JPQL就是一种查询语言&#xff0c;具有与 SQL 相类似的特征&#xff0c; JPQL 是完全面向对象的&#xff0c;具备继承、多态和关联等特性&#xff0c;和hibernate HQL很相似。 查询语句的参数 JPQL 语句支持两种方式的参数定义方式 : 命名参数和位置参数 。 。在同一个查询语句…

taro 填坑之路(一)taro 项目回顾

&#xff08;1&#xff09;像素写法 PX -- 大写&#xff0c;否则会自动成rem &#xff08;2&#xff09;拿取列表第一条数据 let { activity:[firstItem] } this.state; &#xff08;3&#xff09;使用props 需要设置默认值 XXX.defaultProps {changeInput:null } &#xff0…

php 验证 手机号码

最近公司让我将身份证校验改为严格校验&#xff0c;刚开始我使用了网上找到的身份证正则校验进行校验&#xff1a; /^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$|^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}([0-9]|X)$/但是&#xff0c;老板…

powerdesigner设置唯一键,但不是主键的方式

唯一约束 唯一约束与创建唯一索引基本上是一回事&#xff0c;因为在创建唯一约束的时候&#xff0c;系统会创建对应的一个唯一索引&#xff0c;通过唯一索引来实现约束。不过唯一约束更直观的表达了对应列的唯一性&#xff0c;使得对应索引的目的更加清晰&#xff0c;所以一般…

前端开发者如何用脑图快速上手linux

前言 不知道作为一个互联网从业人员的你是否会有过一种学海无涯苦作舟的感受?随着自媒体的兴起,移动互联时代UGC的几何式增长,终身学习&#xff0c;刻意练习大行其道.一个普通人一天接收到的信息&#xff0c;神机妙算的诸葛亮或许三百年才可以搜集。信息源的增加没有提升幸福感…

Yii modules模块配置

在开发过程中&#xff0c;一个项目中&#xff0c;项目的功能可能会分为多个模块&#xff0c;例如&#xff0c;如果我们的项目为电商的管理控制系统的话&#xff0c;这时候我们的项目可能就会分为销售模块&#xff0c;采购模块&#xff0c;财务模块等等&#xff0c;这时候我们如…

Jquery 来获取以及设置CheckBox、 RadioButton、 DropDownList的值

随着Jquery的作用越来越大&#xff0c;使用的朋友也越来越多。在Web中&#xff0c;由于CheckBox、Radiobutton 、DropDownList等控件使用的频率比较高&#xff0c;就关系到这些控件在Jquery中的操作问题。由于Jquery的版本更新很快&#xff0c;代码的写法也改变了许多&#xff…

微信JSSDK获取用户地理位置(经纬度)

最近一直在做公众号开发&#xff0c;这两天公司让我做一个类似钉钉打卡的功能&#xff0c;这时候我需要获取到用户的经纬度&#xff0c; 但是在这之前我只知道在关注微信公众号的时候获取用户地理位置&#xff1a;https://mp.weixin.qq.com/wiki?tresource/res_main&idmp…