基于jquery的表头固定的若干方法

合集下载
相关主题
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

基于jquery的表头固定的若干方法

阅读:96次时间:2011-11-24 14:17:08 字体:[大中小]

A:使用JQuery UI插件,用DIV替换table,overflow-y:hidden达到滚动,让thead绝对定位达到固定的目的,方法如下:复制代码代码如下:

(function($){

$.chromatable = {

defaults: {

width: "900px",

height: "300px",

scrolling: "yes"

}

};

$.fn.chromatable = function(options){

var options = $.extend({}, $.chromatable.defaults, options);

return this.each(function(){

var $this = $(this);

var $uniqueID = $(this).attr("ID") + ("wrapper");

$(this).css('width', options.width).addClass("_scrolling");

$(this).wrap('

');

$(".scrolling_outer").css({'position':'relative'});

$("#"+$uniqueID).css(

{'border':'1px solid #CCCCCC',

'overflow-x':'hidden',

'overflow-y':'auto',

'padding-right':'17px'

});

$("#"+$uniqueID).css('height', options.height);

$("#"+$uniqueID).css('width', options.width);

$(this).before($(this).clone().attr("id", "").addClass("_thead").css(

{'width' : 'auto',

'display' : 'block',

'position':'absolute',

'border':'none',

'border-bottom':'1px solid #CCC',

'top':'1px'

}));

$('._thead').children('tbody').remove();

$(this).each(function( $this ){

if (options.width == "100%" || options.width == "auto") {

$("#"+$uniqueID).css({'padding-right':'0px'});

}

if (options.scrolling == "no") {

$("#"+$uniqueID).before('Expand table');

$("#"+$uniqueID).css({'padding-right':'0px'});

$(".expander").each(

function(int){

$(this).attr("ID", int);

$( this ).bind ("click",function(){

$("#"+$uniqueID).css({'height':'auto'});

$("#"+$uniqueID+" ._thead").remove();

$(this).remove();

});

});

$("#"+$uniqueID).resizable({ handles: 's' }).css("overflow-y", "hidden"); }

});

$curr = $this.prev();

$("thead:eq(0)>tr th",this).each( function (i) {

$("thead:eq(0)>tr th:eq("+i+")", $curr).width( $(this).width());

});

if (options.width == "100%" || "auto"){

$(window).resize(function(){

resizer($this);

});

}

});

};

function resizer($this) {

$curr = $this.prev();

$("thead:eq(0)>tr th", $this).each( function (i) {

$("thead:eq(0)>tr th:eq("+i+")", $curr).width( $(this).width());

});

};

})(jQuery);

页面调用如下:

复制代码代码如下:

...