利用js+css+html實現固定table的列頭不動
Dec 29, 2016 pm 04:37 PM話不多說,跟這小編來一起看吧
1、CSS
<style type="text/css"> #scroll_head { position: absolute; display: none; } </style>
登入後複製
2、Javascript
<script type="text/javascript"> //该函数在上面一个table数据加载完成后调用 //把表头的宽度设置到会滚动的页头去 var copyWidth = function () { var b = $('#data_tbody').prev().find('tr:last').find('th'); var c = $('#scroll_head').find('tr:last').find('th'); for (var i = 0; i < b.length; i++) { var newWith = b.eq(i).width(); if ($.browser.msie) { newWith += 1; } c.eq(i).width(newWith); } } $(function () { $(window).scroll(function () { if ($('#data_tbody').length > 0) { var thead = $('#data_tbody').prev(); var thOffset = thead.offset(); var scTop = $(window).scrollTop(); //滚动条相对top的位置 if (scTop > thOffset.top) { //滚动条滚到thead及以下的位置,用临时的thead代替显示 $('#scroll_head').css('display', 'block'); $('#scroll_head').offset({ top: scTop, left: thOffset.left }); } else { //滚动条滚到thead上的位置,用table的原始thead显示 $('#scroll_head').css('display', 'none'); } } }); }); </script>
登入後複製
2、Javascript
<div id="data_div"> <table> @*thead内容及样式同scroll_head中的thead*@ @*thead使用深背景色,避免滚动时和tbody内容重叠显示*@ <thead> <tr> @*一级标题*@ <th class="tt1" colspan="2">一级1</th> <th class="tt2" colspan="5">一级2</th> <th class="tt3" colspan="6">一级3</th> </tr> <tr> @*二级标题*@ <th style="width: 23px;">二级11</th> <th style="width: 36px;">二级12</th> <th class="tt" style="width: 40px;">二级21</th> <th class="tt" style="width: 30px;">二级22</th> <th class="tt" style="width: 30px;">二级23</th> <th class="tt" style="width: 30px;">二级23</th> <th class="tt" style="width: 30px;">二级24</th> <th class="tt" style="width: 30px;">二级25</th> <th class="tt" style="width: 30px;">二级31</th> <th class="tt" style="width: 30px;">二级32</th> <th class="tt" style="width: 30px;">二级33</th> <th class="tt" style="width: 30px;">二级33</th> <th class="tt" style="width: 30px;">二级34</th> <th class="tt" style="width: 30px;">二级35</th> <th class="tt" style="width: 30px;">二级36</th> </tr> </thead> <tbody id="data_tbody"> 数据内容,在数据加载完成后调用copyWidth()函数解决兼容性 </tbody> </table> </div> <div id="scroll_head" style="display:block; top: 168px; left: 0px; position: relative;"> <table width="100%"> <thead> @*thead使用深背景色,避免滚动时和tbody内容重叠显示*@ <tr> @*一级标题*@ <th class="tt1" colspan="2">一级1</th> <th class="tt2" colspan="5">一级2</th> <th class="tt3" colspan="6">一级3</th> </tr> <tr> @*二级标题*@ <th style="width: 23px;">二级11</th> <th style="width: 36px;">二级12</th> <th class="tt" style="width: 40px;">二级21</th> <th class="tt" style="width: 30px;">二级22</th> <th class="tt" style="width: 30px;">二级23</th> <th class="tt" style="width: 30px;">二级23</th> <th class="tt" style="width: 30px;">二级24</th> <th class="tt" style="width: 30px;">二级25</th> <th class="tt" style="width: 30px;">二级31</th> <th class="tt" style="width: 30px;">二级32</th> <th class="tt" style="width: 30px;">二级33</th> <th class="tt" style="width: 30px;">二级33</th> <th class="tt" style="width: 30px;">二级34</th> <th class="tt" style="width: 30px;">二级35</th> <th class="tt" style="width: 30px;">二级36</th> </tr> </thead> </table> </div>
登入後複製
🜎
以上就是本文的全部內容,希望本文的內容對大家的學習或工作能帶來一定的幫助,如果有疑問大家可以留言交流,同時也希望多多支持PHP中文網!
更多利用js+css+html實現固定table的列頭不動相關文章請關注PHP中文網!
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前
By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
擊敗分裂小說需要多長時間?
3 週前
By DDD
R.E.P.O.保存文件位置:在哪里以及如何保護它?
3 週前
By DDD

熱門文章
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前
By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前
By 尊渡假赌尊渡假赌尊渡假赌
擊敗分裂小說需要多長時間?
3 週前
By DDD
R.E.P.O.保存文件位置:在哪里以及如何保護它?
3 週前
By DDD

熱門文章標籤

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)