表格的头部固定效果通过css及jquery分别实现
网站建设 2023-01-28 20:49www.1681989.com免费网站
1.第一种方式利用css的样式来实现表格的头部固定
<html xmlns="http://.w3./1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=GB2312" />
<title>无标题文档</title>
<style type="text/css">
.a{
position:relative;
:expression(this.offsetParent.scrollTop); //这里的offsetParent是最近的有固定样式的父级元素,原理就是不断的刷新相对于该父级元素的scrollTop来实现头部固定
background:blue;
text-align:center;
z-dex:10;
}
.maDIV{
overflow:scroll;
height:100px;
}
</style>
</head>
<body>
<div class="maDIV">
<table cellpaddg="0" id="tab1" cellspacg="0" border="1" class="itemList">
<thead>
<tr style="background-color: #eeeeee; marg: 0px; le-height: 20px; font-weight: bold;
paddg: 0px 0px 0px 0px;" class="a">
<td> 列1</td>
<td> 列2</td>
<td> 列3 </td>
<td> 列4</td>
</tr>
</thead>
<tbody>
...
2.第二种方法是用jquery把原来table的头隐藏,然后复制出一个一模一样的然后sertBefore到table前面
des.html测试页面
<html xmlns="http://.w3./1999/xhtml">
<head runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>quber@163._jQuery实现表头固定效果(挺不错的!!!)</title>
<script src="jquery-1.4.js" type="text/javascript"></script>
<script src="jquery.remaHead.js" type="text/javascript"></script>
<style type="text/css">
.itemList
{
border: solid 1px #;
overflow: hidden
width: 100%;
border-collapse: collapse;
}
.itemList td
{
paddg: 0px 0px 0px 0px;
color: #444444;
border: solid 1px #;
text-align: center;
le-height: 20px;
}
</style>
<script type="text/javascript">
$(function() {
$.remaHead("tab1","div1");
});
</script>
</head>
<body>
<form id="form1" runat="server">
<div style=" height: 250px; overflow:scroll;" id="div1">
<table cellpaddg="0" id="tab1" cellspacg="0" border="1" class="itemList">
<thead>
<tr style="background-color: #eeeeee; marg: 0px; le-height: 20px; font-weight: bold;
paddg: 0px 0px 0px 0px;">
<td> 列1</td>
<td>列2 </td>
<td> 列3</td>
<td> 列4</td>
</tr>
</thead>
<tbody>
<tr><td>我是测试的数据行…………</td><td>我是测试的数据行…………</td><td>我是测试的数据行…………</td><td>我是测试的数据行…………</td></tr>
....
jquery.remaHead.js 页面
;(function($){
$.extend({
//原理就是把原来的头给隐藏掉了,然后复制一个头出来插入到table的上面来实现头部固定
"remaHead":function(tableId,tableParentDivId){
var obj = document.getElementById("tableHeaderDiv" + tableId);
if (obj) {
jQuery(obj).remove();
}
var browserName = navigator.appName;
var ver = navigator.appVersion;
var browserVersion = parseFloat(ver.substrg(ver.dexOf("MSIE") + 5, ver.lastIndexOf("Wdows")));
var content = document.getElementById(tableParentDivId);
var scrollWidth = content.offsetWidth - content.clientWidth;
var tableOrg = jQuery("#" + tableId)
var table = tableOrg.clone();
table.attr("id", "cloneTable");
var tableClone = jQuery(tableOrg).fd("tr").each(function() {
});
var tableHeader = jQuery(tableOrg).fd("thead");
var tableHeaderHeight = tableHeader.height();
tableHeader.hide();
var colsWidths = jQuery(tableOrg).fd("tbody tr:first td").map(function() {
return jQuery(this).width();
});
//alert(colsWidths.get().jo(","));用get()可以获取数组的dom元素
var tableCloneCols = jQuery(table).fd("thead tr:first td")
if (colsWidths.size() > 0) {
for (i = 0; i < tableCloneCols.size(); i++) {
if (i == tableCloneCols.size() - 1) {
if (browserVersion == 8.0)
tableCloneCols.eq(i).width(colsWidths[i] + scrollWidth);
else
tableCloneCols.eq(i).width(colsWidths[i]);
} else {
tableCloneCols.eq(i).width(colsWidths[i]);
}
}
}
var headerDiv = document.createElement("div");
headerDiv.appendChild(table[0]);
jQuery(headerDiv).css("height", tableHeaderHeight);
jQuery(headerDiv).css("overflow", "hidden");
jQuery(headerDiv).css("z-dex", "20");
jQuery(headerDiv).css("width", "100%");
jQuery(headerDiv).attr("id", "tableHeaderDiv" + tableId);
jQuery(headerDiv).sertBefore(tableOrg.parent());
}
});
})(jQuery);
复制代码
代码如下:<html xmlns="http://.w3./1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=GB2312" />
<title>无标题文档</title>
<style type="text/css">
.a{
position:relative;
:expression(this.offsetParent.scrollTop); //这里的offsetParent是最近的有固定样式的父级元素,原理就是不断的刷新相对于该父级元素的scrollTop来实现头部固定
background:blue;
text-align:center;
z-dex:10;
}
.maDIV{
overflow:scroll;
height:100px;
}
</style>
</head>
<body>
<div class="maDIV">
<table cellpaddg="0" id="tab1" cellspacg="0" border="1" class="itemList">
<thead>
<tr style="background-color: #eeeeee; marg: 0px; le-height: 20px; font-weight: bold;
paddg: 0px 0px 0px 0px;" class="a">
<td> 列1</td>
<td> 列2</td>
<td> 列3 </td>
<td> 列4</td>
</tr>
</thead>
<tbody>
...
2.第二种方法是用jquery把原来table的头隐藏,然后复制出一个一模一样的然后sertBefore到table前面
des.html测试页面
复制代码
代码如下:<html xmlns="http://.w3./1999/xhtml">
<head runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>quber@163._jQuery实现表头固定效果(挺不错的!!!)</title>
<script src="jquery-1.4.js" type="text/javascript"></script>
<script src="jquery.remaHead.js" type="text/javascript"></script>
<style type="text/css">
.itemList
{
border: solid 1px #;
overflow: hidden
width: 100%;
border-collapse: collapse;
}
.itemList td
{
paddg: 0px 0px 0px 0px;
color: #444444;
border: solid 1px #;
text-align: center;
le-height: 20px;
}
</style>
<script type="text/javascript">
$(function() {
$.remaHead("tab1","div1");
});
</script>
</head>
<body>
<form id="form1" runat="server">
<div style=" height: 250px; overflow:scroll;" id="div1">
<table cellpaddg="0" id="tab1" cellspacg="0" border="1" class="itemList">
<thead>
<tr style="background-color: #eeeeee; marg: 0px; le-height: 20px; font-weight: bold;
paddg: 0px 0px 0px 0px;">
<td> 列1</td>
<td>列2 </td>
<td> 列3</td>
<td> 列4</td>
</tr>
</thead>
<tbody>
<tr><td>我是测试的数据行…………</td><td>我是测试的数据行…………</td><td>我是测试的数据行…………</td><td>我是测试的数据行…………</td></tr>
....
jquery.remaHead.js 页面
复制代码
代码如下:;(function($){
$.extend({
//原理就是把原来的头给隐藏掉了,然后复制一个头出来插入到table的上面来实现头部固定
"remaHead":function(tableId,tableParentDivId){
var obj = document.getElementById("tableHeaderDiv" + tableId);
if (obj) {
jQuery(obj).remove();
}
var browserName = navigator.appName;
var ver = navigator.appVersion;
var browserVersion = parseFloat(ver.substrg(ver.dexOf("MSIE") + 5, ver.lastIndexOf("Wdows")));
var content = document.getElementById(tableParentDivId);
var scrollWidth = content.offsetWidth - content.clientWidth;
var tableOrg = jQuery("#" + tableId)
var table = tableOrg.clone();
table.attr("id", "cloneTable");
var tableClone = jQuery(tableOrg).fd("tr").each(function() {
});
var tableHeader = jQuery(tableOrg).fd("thead");
var tableHeaderHeight = tableHeader.height();
tableHeader.hide();
var colsWidths = jQuery(tableOrg).fd("tbody tr:first td").map(function() {
return jQuery(this).width();
});
//alert(colsWidths.get().jo(","));用get()可以获取数组的dom元素
var tableCloneCols = jQuery(table).fd("thead tr:first td")
if (colsWidths.size() > 0) {
for (i = 0; i < tableCloneCols.size(); i++) {
if (i == tableCloneCols.size() - 1) {
if (browserVersion == 8.0)
tableCloneCols.eq(i).width(colsWidths[i] + scrollWidth);
else
tableCloneCols.eq(i).width(colsWidths[i]);
} else {
tableCloneCols.eq(i).width(colsWidths[i]);
}
}
}
var headerDiv = document.createElement("div");
headerDiv.appendChild(table[0]);
jQuery(headerDiv).css("height", tableHeaderHeight);
jQuery(headerDiv).css("overflow", "hidden");
jQuery(headerDiv).css("z-dex", "20");
jQuery(headerDiv).css("width", "100%");
jQuery(headerDiv).attr("id", "tableHeaderDiv" + tableId);
jQuery(headerDiv).sertBefore(tableOrg.parent());
}
});
})(jQuery);
网站设计
- 静宁会SEO的网站建设公司:全面提升您的网络影
- 提升在线业务的关键:选择最佳的丽水网站建设
- 浙江网站优化发展潜力如何
- 井研专业的网站建设公司:打造您的在线品牌
- 灵山SEO网站建设公司:提升您的在线业务表现
- 蒙城网站建设优化公司:提升您网站表现的理想
- 阳谷企业网站优化:提升线上业务力的关键
- 樟树专业的网站建设公司:打造您在线业务的坚
- 通河百度SEO排名的策略与技巧
- 重庆百度快照排名如何进行精准的客户引流
- 重庆百度快照排名
- 常宁便宜的建站公司:助您轻松打造在线业务
- 巫溪百度网站优化:提升网站曝光率与流量的关
- 湖北整站优化怎么做才能放大客户需求
- 闸北网站建设多少钱?全面解析与预算规划
- 辽宁企业网站优化怎么做电话营销