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 相关文章推荐
javascript 三种编解码方式
Feb 01 Javascript
JavaScript删除数组元素的方法
Mar 20 Javascript
JavaScript中数据结构与算法(四):串(BF)
Jun 19 Javascript
js中substr,substring,indexOf,lastIndexOf,split,replace的用法详解
Nov 09 Javascript
AngularJs  E2E Testing 详解
Sep 02 Javascript
React Js 微信禁止复制链接分享禁止隐藏右上角菜单功能
May 26 Javascript
jQuery实现通过方向键控制div块上下左右移动的方法【测试可用】
Apr 26 jQuery
让axios发送表单请求形式的键值对post数据的实例
Aug 11 Javascript
Element-UI踩坑之Pagination组件的使用
Oct 29 Javascript
浅析Vue 防抖与节流的使用
Nov 14 Javascript
详解Vue 单文件组件的三种写法
Feb 19 Javascript
如何将Node.js中的回调转换为Promise
Nov 10 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
PHP设计模式之迭代器模式
2016/06/17 PHP
php过滤输入操作之htmlentities与htmlspecialchars用法分析
2017/02/17 PHP
PDO::commit讲解
2019/01/27 PHP
基于PHP的微信公众号的开发流程详解
2020/08/07 PHP
js获取变量
2006/08/24 Javascript
基于jquery的气泡提示效果
2010/05/31 Javascript
Jqyery中同等与js中windows.onload的应用
2011/05/10 Javascript
JS鼠标事件大全 推荐收藏
2011/11/01 Javascript
关于JS判断图片是否加载完成且获取图片宽度的方法
2013/04/09 Javascript
JavaScript获得url查询参数的方法
2015/07/02 Javascript
JavaScript实现搜索框的自动完成功能(一)
2016/02/25 Javascript
jquery checkbox无法用attr()二次勾选问题的解决方法
2016/07/22 Javascript
再谈Javascript中的异步以及如何异步
2016/08/19 Javascript
JQuery实现DIV其他动画效果的简单实例
2016/09/18 Javascript
用js控件div的滚动条,让它在内容更新时自动滚到底部的实现方法
2016/10/27 Javascript
深入掌握 react的 setState的工作机制
2017/09/27 Javascript
AngularJS实现表单验证功能详解
2017/10/12 Javascript
Vue实现本地购物车功能
2018/12/05 Javascript
Bootstrap告警框(alert)实现弹出效果和短暂显示后上浮消失的示例代码
2020/08/27 Javascript
Vue3不支持Filters过滤器的问题
2020/09/24 Javascript
解决element-ui的下拉框有值却无法选中的情况
2020/11/07 Javascript
[01:04:01]2014 DOTA2国际邀请赛中国区预选赛 5 23 CIS VS DT第一场
2014/05/24 DOTA
python三元运算符实现方法
2013/12/17 Python
详解python上传文件和字符到PHP服务器
2017/11/24 Python
Pytorch实现神经网络的分类方式
2020/01/08 Python
python标准库os库的函数介绍
2020/02/12 Python
AmazeUI 点击元素显示全屏的实现
2020/08/25 HTML / CSS
上海天奕面试题笔试题
2015/04/19 面试题
配件采购员岗位职责
2013/12/03 职场文书
超市促销活动方案
2014/03/05 职场文书
科级干部群众路线教育实践活动个人对照检查材料
2014/09/19 职场文书
出国签证在职证明
2014/09/20 职场文书
2014大学校园光棍节活动策划书
2014/09/29 职场文书
毕业生入职感言
2015/07/31 职场文书
python使用pymysql模块操作MySQL
2021/06/16 Python
python可视化分析绘制带趋势线的散点图和边缘直方图
2022/06/25 Python