本文实例讲述了jQuery实现冻结表头的方法。分享给大家供大家参考。具体如下:
前段时间做项目时候由于需要显示一个列表,但是由于数据太多在滚动的时候表头必须冻结住,所以就写了下面这个脚本(曾经在网上也找过相应的脚本,但是不怎么理想所以就自己写了,但是目前由于项目仅仅用到了表头的冻结,而不需要指定列冻结所以目前只能算个不完整的脚本,不过一般的仅仅需要表头冻结就可以使用了),现在先看看截图:

这样实现了表头的冻结,下面表体内容可以自由滚动
看下代码:
//为jquery扩展一个CloneTableHeader 方法
jQuery.fn.CloneTableHeader = function(tableId, tableParentDivId) {
//获取冻结表头所在的DIV,如果DIV已存在则移除
var obj = document.getElementById(“tableHeaderDiv” + tableId);
if (obj) {
jQuery(obj).remove();
}
var browserName = navigator.appName;//获取浏览器信息,用于后面代码区分浏览器
var ver = navigator.appVersion;
var browserVersion = parseFloat(ver.substring(ver.indexOf(“MSIE”) + 5, ver.lastIndexOf(“Windows”)));
var content = document.getElementById(tableParentDivId);
var scrollWidth = content.offsetWidth – content.clientWidth;
var tableOrg = jQuery(“#” + tableId);//获取表内容
var table = tableOrg.clone();//克隆表内容
table.attr(“id”, “cloneTable”);
//注意:需要将要冻结的表头放入thead中
var tableHeader = jQuery(tableOrg).find(“thead”);
var tableHeaderHeight = tableHeader.height();
tableHeader.hide();
var colsWidths = jQuery(tableOrg).find(“tbody tr:first td”).map(function() {
return jQuery(this).width();
});//动态获取每一列的宽度
var tableCloneCols = jQuery(table).find(“thead tr:first td”)
if (colsWidths.size() > 0) {//根据浏览器为冻结的表头宽度赋值(主要是区分IE8)
for (i = 0; i < tableCloneCols.size(); i++) {
if (i == tableCloneCols.size() – 1) {
if (browserVersion == 8.0)
tableCloneCols.eq(i).width(colsWidths[i] + scrollWidth);










