bootstrap-table實(shí)現(xiàn)表頭固定以及列固定的方法示例
之前使用bootstrap寫了一個(gè)報(bào)表表格,最近突然找到我,說(shuō)讓我看看能不能將表格的表頭和第一列進(jìn)行固定,這樣的話方便查看數(shù)據(jù),于是,我開(kāi)始了苦逼的研究起來(lái),畢竟我是個(gè)后端啊,對(duì)于前端的樣式問(wèn)題,特別是小功能,煩的一批
這里就記錄下我的研究成果
一:引入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下載地址:http://www.dbjr.com.cn/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時(shí),不要引入jquery2.0.0(包括2.0.0)版本以下,如果你引入了2.0.0版本以下的jquery的話,當(dāng)你編寫完代碼之后,在控制臺(tái)會(huì)出現(xiàn)如下錯(cuò)誤:
二:編寫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標(biāo)簽中的data-toggle="table"表示的是啟用bootstrap表格,data-height="200"表示設(shè)置表格的高度,用于配置固定表頭。由于我這里編寫的表格數(shù)據(jù)較少,所以展示出來(lái)的數(shù)據(jù)可能不會(huì)出現(xiàn)滑輪,看不出來(lái)固定表頭現(xiàn)象,你可以向表格中添加多一點(diǎn)數(shù)據(jù)就可以了
三:固定列
<script> $(function(){ //#table表示的是上面table表格中的id $("#table").bootstrapTable('destroy').bootstrapTable({ fixedColumns: true, fixedNumber: 1 //固定列數(shù) }); }) </script>
四:當(dāng)瀏覽器窗口變化時(shí),表頭與表格不對(duì)齊解決:
<script> $(function(){ $('#table').bootstrapTable(); $(window).resize(function () { $('#table').bootstrapTable('resetView'); }); }) </script>
五:初次展示時(shí)表頭和表格數(shù)據(jù)不對(duì)齊解決(個(gè)人使用的方法,方法有點(diǎn)傻)
進(jìn)過(guò)上面的過(guò)程我們已經(jīng)實(shí)現(xiàn)了表格的表格和列固定功能了,于是我便開(kāi)始將報(bào)表修改起來(lái),開(kāi)始修改起來(lái)十分的輕松,沒(méi)有問(wèn)題,但是,當(dāng)我修改到一個(gè)報(bào)表的時(shí)候發(fā)現(xiàn),開(kāi)始的時(shí)候,表頭和數(shù)據(jù)之間就發(fā)生了不對(duì)齊現(xiàn)象:
于是我開(kāi)始在網(wǎng)上搜索起來(lái),但是網(wǎng)上搜索的答案根本解決不了,例如:
找到bootstrap-table的源碼中
if (this.options.showHeader && this.options.height) { this.$tableHeader.show(); //注釋掉下面兩行 取消表頭初始化解決表頭和內(nèi)容不對(duì)齊問(wèn)題 //this.resetHeader(); //padding += this.$header.outerHeight(); }
不知道寫這個(gè)的兄弟有沒(méi)有自己測(cè)試過(guò),反正我注釋了之后,確實(shí)表頭和數(shù)據(jù)對(duì)齊了,但是表頭固定功能消失了,表頭和數(shù)據(jù)不對(duì)齊的原因就是因?yàn)槟阍O(shè)置了固定表頭影響的,你這樣將表頭固定功能去掉了,那么我直接將table標(biāo)簽中的data-height="200"去掉不久行了嗎,為什么還要改源碼呢?
于是我自己開(kāi)始研究起來(lái)
最后我使用審查元素找到錯(cuò)位的表頭位置,發(fā)現(xiàn)這樣一段代碼
<div class="fht-cell" style="width: 146px;"></div>
這里將寬度設(shè)置為了146但是我的數(shù)據(jù)寬度只有120,這才造成了錯(cuò)位,
然后我找到bootstrap-table源碼設(shè)置div的class為fht-cell寬度的代碼位置
雖然我找到了問(wèn)題所在,但是源碼哪里出問(wèn)題了,我還是不清楚,有知道的伙伴,歡迎告訴我答案
既然我不知道源碼出問(wèn)題出在哪,那么我就使用十分傻的方法,直接設(shè)置class為fht-cell的寬度,將之前寬度為146的覆蓋
.fht-cell{width:120px!important;}
然后打開(kāi)觀看,錯(cuò)誤問(wèn)題解決了?。?!
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- bootstrap-table組合表頭的實(shí)現(xiàn)方法
- Bootstrap-table使用footerFormatter做統(tǒng)計(jì)列功能
- bootstrap-table實(shí)現(xiàn)服務(wù)器分頁(yè)的示例 (spring 后臺(tái))
- bootstrap-table+treegrid實(shí)現(xiàn)樹(shù)形表格
- bootstrap-table.js擴(kuò)展分頁(yè)工具欄(增加跳轉(zhuǎn)到xx頁(yè))功能
- bootstrap-table formatter 使用vue組件的方法
- Bootstrap-table自定義可編輯每頁(yè)顯示記錄數(shù)
- Node.js中Bootstrap-table的兩種分頁(yè)的實(shí)現(xiàn)方法
- Bootstrap table學(xué)習(xí)筆記(2) 前后端分頁(yè)模糊查詢
- bootstrap table 服務(wù)器端分頁(yè)例子分享
- Bootstrap table分頁(yè)問(wèn)題匯總
- bootstrap-table后端分頁(yè)功能完整實(shí)例
相關(guān)文章
如何用js將blob為pcm格式轉(zhuǎn)換為MP3格式
要將PCM文件轉(zhuǎn)換為MP3文件,您可以使用Js實(shí)現(xiàn),這篇文章主要給大家介紹了關(guān)于如何用js將blob為pcm格式轉(zhuǎn)換為MP3格式的相關(guān)資料,需要的朋友可以參考下2023-11-11javascript算法學(xué)習(xí)實(shí)現(xiàn)代碼
有1到100000共10萬(wàn)個(gè)數(shù)。從中隨機(jī)抽走兩個(gè)。再把原來(lái)的數(shù)字順序打亂。如何快速找到被抽走的兩個(gè)數(shù)2011-04-04JavaScript 學(xué)習(xí)點(diǎn)滴記錄
HTML DOM (Document Object Model文檔對(duì)象模型) DOM是一種與瀏覽器,平臺(tái),語(yǔ)言的接口,使得你可以訪問(wèn)頁(yè)面其他的標(biāo)準(zhǔn)組件. DOM是以層次結(jié)構(gòu)組織的節(jié)點(diǎn)或信息片斷的集合.2009-04-04html dom節(jié)點(diǎn)操作(獲取/修改/添加或刪除)
DOM 是關(guān)于如何獲取、修改、添加或刪除 HTML 元素的標(biāo)準(zhǔn),下面為大家介紹下html dom節(jié)點(diǎn)操作,感興趣的朋友可以參考下2014-01-01JavaScript實(shí)現(xiàn)二分查找實(shí)例代碼
二分查找的前提為:數(shù)組、有序。這篇文章主要介紹了JavaScript實(shí)現(xiàn)二分查找實(shí)例代碼,需要的朋友可以參考下2017-02-02通用javascript代碼判斷版本號(hào)是否在版本范圍之間
通用判斷版本號(hào)是否在兩者之間,也可以搭配判斷是否大于某版本號(hào),小于取反即可,本文給大家介紹通用javascript代碼判斷版本號(hào)是否在版本范圍之間,需要的朋友參考下2015-11-11es6中使用map簡(jiǎn)化復(fù)雜條件判斷操作實(shí)例詳解
這篇文章主要介紹了es6中使用map簡(jiǎn)化復(fù)雜條件判斷操作,結(jié)合實(shí)例形式詳細(xì)分析了傳統(tǒng)方法與map簡(jiǎn)化復(fù)雜條件判斷的相關(guān)操作技巧,需要的朋友可以參考下2020-02-02