Jquery原生态实现表格header头随滚动条滚动而滚动


Posted in Javascript onMarch 18, 2014

最近在做一个项目,功能已经实现,突然用户要求表头是浮动的(因为内容在同一页面展示,当滚动时,看不到列头)。由于功能已经实现使用jquery+纯html,为了改动少只能使用jquery原生态实现滚动。

html表头代码:

<tr class="header" > 
<td width="150" style="border-bottom:0px;"> </td> 
<td colspan="2" style="border-bottom:0px;"> </td> 
<td colspan="7">师资力量</td> 
<td colspan="14">科研</td> 
<td style="border-bottom:0px;"> </td> 
</tr> 
<tr class="header"> 
<td width="150" style="border-top:0px;border-bottom:0px;"> </td> 
<td colspan="2" style="border-top:0px;">人才培养</td> 
<td colspan="3">职称结构</td> 
<td colspan="2">学位结构</td> 
<td colspan="2">生师比</td> 
<td colspan="2">科研项目</td> 
<td colspan="6">科研成果奖</td> 
<td colspan="6">科研论文</td> 
<td style="border-top:0px;border-bottom:0px;"> </td> 
</tr> 
<tr class="header"> 
<td width="150" style="border-top:0px;">教学单位</td> 
<td><a href="javascript:void(0);" id="undergraduate">本科生数</a></td> 
<td><a href="javascript:void(0);" id="graduate">研究生数</a></td> 
<td>教职工数</td> 
<td>高级教职工数</td> 
<td>中级教职工数</td> 
<td>博士学位职工数</td> 
<td>硕士学位教职工数</td> 
<td>本科生生师比</td> 
<td>研究生生师比</td> 
<td>纵向项目</td> 
<td>横向项目</td> 
<td>国家级科研成果</td> 
<td>部级科研成果</td> 
<td>省级科研成果</td> 
<td>地级科研成果</td> 
<td>校级科研成果</td> 
<td>其它科研成果</td> 
<td>核心期刊论文</td> 
<td>一类奖励期刊论文</td> 
<td>二类奖励期刊论文</td> 
<td>三类奖励期刊论文</td> 
<td>一般期刊论文</td> 
<td>国外期刊论文</td> 
<td style="border-top:0px;">财务工资</td> 
</tr>

jquery代码:
$(window).scroll(function(){ 
var headers = $(".header");//获取所有表头行,当前的是3行表头 
var yy = $(this).scrollTop();//滚动条top值 
if(yy>55){ 
yy = yy-55; 
} 
var height1 = yy;//第一行top值 
var height2 = $(headers[0]).height()+yy;<span style="font-family:Arial,Helvetica,sans-serif">//第一行top值,第一行行高与</span><span style="font-family:Arial,Helvetica,sans-serif">滚动条top值之和</span><span style="font-family:Arial,Helvetica,sans-serif"> 
</span> var height3 = $(headers[0]).height()+$(headers[1]).height()+yy; 
$(headers[0]).css({"position":"absolute",top:height1+"px"});//浮动行 
$(headers[1]).css({"position":"absolute",top:height2+"px"}); 
$(headers[2]).css({"position":"absolute",top:height3+"px"}); [javascript] view plaincopy 
$("#hiddenTd").height($(headers[0]).height()+$(headers[1]).height()+$(headers[2]).height());<span style="font-family:Arial,Helvetica,sans-serif">//由于表头浮动,对应的表内容自动上移,为了浮动表头不会覆盖表内容,设置空行,高度为表头高</span>

注意:多行表头时,单元格不要使用rowspan属性,否则表头会错位。
Javascript 相关文章推荐
js计数器代码
Nov 04 Javascript
JS的递增/递减运算符和带操作的赋值运算符的等价式
Dec 08 Javascript
JavaScrip单线程引擎工作原理分析
Sep 04 Javascript
JavaScript 模拟类机制及私有变量的方法及思路
Jul 10 Javascript
使用requestAnimationFrame实现js动画性能好
Aug 06 Javascript
jQuery插件JWPlayer视频播放器用法实例分析
Jan 11 Javascript
Three.js利用顶点绘制立方体的方法详解
Sep 27 Javascript
浅谈JavaScript的innerWidth与innerHeight
Oct 12 Javascript
JS+HTML+CSS实现轮播效果
Nov 28 Javascript
利用angular、react和vue实现相同的面试题组件
Feb 19 Javascript
jQuery实现轮播图效果
Nov 26 jQuery
vue3+typescript实现图片懒加载插件
Oct 26 Javascript
使用CSS3的scale实现网页整体缩放
Mar 18 #Javascript
使用jquery实现IE下按backspace相当于返回操作
Mar 18 #Javascript
运用JQuery的toggle实现网页加载完成自动弹窗
Mar 18 #Javascript
js身份证判断方法支持15位和18位
Mar 18 #Javascript
验证码在IE中不刷新而谷歌等浏览器正常的解决方案
Mar 18 #Javascript
用js将内容复制到剪贴板兼容浏览器
Mar 18 #Javascript
javascript页面上使用动态时间具体实现
Mar 18 #Javascript
You might like
桌面中心(一)创建数据库
2006/10/09 PHP
php 多关键字 高亮显示实现代码
2012/04/23 PHP
PHP制作用户注册系统
2015/10/23 PHP
PHP+redis实现的限制抢购防止商品超发功能详解
2019/09/19 PHP
二级域名转向类
2006/11/09 Javascript
用javascript获取textarea中的光标位置
2008/05/06 Javascript
初窥JQuery-Jquery简介 入门了解篇
2010/11/25 Javascript
基于jquery的从一个页面跳转到另一个页面的指定位置的实现代码(带平滑移动的效果)
2011/05/24 Javascript
jquery图片轮播插件仿支付宝2013版全屏图片幻灯片
2014/04/03 Javascript
js实现带按钮的上下滚动效果
2015/05/12 Javascript
JS实现跟随鼠标的链接文字提示框效果
2015/08/06 Javascript
每日十条JavaScript经验技巧(一)
2016/06/23 Javascript
将json转换成struts参数的方法
2016/11/08 Javascript
vue实现商城购物车功能
2017/11/27 Javascript
js中apply和Math.max()函数的问题及区别介绍
2018/03/27 Javascript
Vue项目自动转换 px 为 rem的实现方法
2018/10/29 Javascript
nodejs使用node-xlsx生成excel的方法示例
2019/08/22 NodeJs
js实现秒表计时器
2019/12/16 Javascript
[01:02:25]2014 DOTA2华西杯精英邀请赛5 24 NewBee VS VG
2014/05/25 DOTA
python实用代码片段收集贴
2015/06/03 Python
python读取LMDB中图像的方法
2018/07/02 Python
Python数据抓取爬虫代理防封IP方法
2018/12/23 Python
Python生成器的使用方法和示例代码
2019/03/04 Python
python使用参数对嵌套字典进行取值的方法
2019/04/26 Python
python 猴子补丁(monkey patch)
2019/06/26 Python
python+Django+pycharm+mysql 搭建首个web项目详解
2019/11/29 Python
Python跑循环时内存泄露的解决方法
2020/01/13 Python
使用python-Jenkins批量创建及修改jobs操作
2020/05/12 Python
分享全球十款超强HTML5开发工具
2014/05/14 HTML / CSS
HTML5 Canvas实现360度全景图的示例代码
2018/01/29 HTML / CSS
小学生家长评语集锦
2014/01/30 职场文书
离婚协议书范本样本
2014/08/19 职场文书
党的群众路线教育实践活动个人剖析材料
2014/10/07 职场文书
小学数学国培研修日志
2015/11/13 职场文书
只用50行Python代码爬取网络美女高清图片
2021/06/02 Python
vue中控制mock在开发环境使用,在生产环境禁用方式
2022/04/06 Vue.js