Chinaunix首页 | 论坛 | 博客
  • 博客访问: 26188017
  • 博文数量: 2065
  • 博客积分: 10377
  • 博客等级: 上将
  • 技术积分: 21525
  • 用 户 组: 普通用户
  • 注册时间: 2008-11-04 17:50
文章分类

全部博文(2065)

文章存档

2012年(2)

2011年(19)

2010年(1160)

2009年(969)

2008年(153)

分类: 系统运维

2010-03-11 22:05:42

JQuery实现表格滚动

[整理人:遥方  整理时间:2010-2-27]

一、实现表格滚动功能

示例代码如下:

Index.html代码如下

3C//DTD XHTML 1.0 Transitional//EN" "">

       Scrollable HTML table

      

      

      

      

             

                    

                    

                    

             

      

      

             

                    

             

                    

             

                    

             

                    

             

                    

      

Name Surename Age
John

                    

Smith

                    

30

             

John

                    

Smith

                    

31

             

John

                    

Smith

                    

32

             

John

                    

Smith

                    

33

             

John

                    

Smith

                    

34

             

注意:只需要将

表格头部放置到 标签里面即可。

然后数据可以放入到 里面即可!

webtoolkit.scrollabletable.js 内容如下:

/**

*

*  Scrollable HTML table

* 

*

**/

function ScrollableTable (tableEl, tableHeight, tableWidth) {

      this.initIEengine = function () {

             this.containerEl.style.overflowY = 'auto';

              if (this.tableEl.parentElement.clientHeight - this.tableEl.offsetHeight < 0) {

                     this.tableEl.style.width = this.newWidth - this.scrollWidth +'px';

              } else {

                     this.containerEl.style.overflowY = 'hidden';

                     this.tableEl.style.width = this.newWidth +'px';

              }

 

              if (this.thead) {

                     var trs = this.thead.getElementsByTagName('tr');

                     for (x=0; x

                            trs[x].style.position ='relative';

                            trs[x].style.setExpression("top",  "this.parentElement.parentElement.parentElement.scrollTop + 'px'");

                     }

              }

             if (this.tfoot) {

                     var trs = this.tfoot.getElementsByTagName('tr');

                     for (x=0; x

                            trs[x].style.position ='relative';

                            trs[x].style.setExpression("bottom",  "(this.parentElement.parentElement.offsetHeight - this.parentElement.parentElement.parentElement.clientHeight - this.parentElement.parentElement.parentElement.scrollTop) + 'px'");

                     }

              }

             eval("window.attachEvent('onresize', function () { document.getElementById('" + this.tableEl.id + "').style.visibility = 'hidden'; document.getElementById('" + this.tableEl.id + "').style.visibility = 'visible'; } )");

       };

      this.initFFengine = function () {

              this.containerEl.style.overflow = 'hidden';

              this.tableEl.style.width = this.newWidth + 'px';

             var headHeight = (this.thead) ? this.thead.clientHeight : 0;

              var footHeight = (this.tfoot) ? this.tfoot.clientHeight : 0;

              var bodyHeight = this.tbody.clientHeight;

              var trs = this.tbody.getElementsByTagName('tr');

              if (bodyHeight >= (this.newHeight - (headHeight + footHeight))) {

                     this.tbody.style.overflow = '-moz-scrollbars-vertical';

                     for (x=0; x

                            var tds = trs[x].getElementsByTagName('td');

                            tds[tds.length-1].style.paddingRight += this.scrollWidth + 'px';

                     }

              } else {

                     this.tbody.style.overflow = '-moz-scrollbars-none';

              }

 

              var cellSpacing = (this.tableEl.offsetHeight - (this.tbody.clientHeight + headHeight + footHeight)) / 4;

              this.tbody.style.height = (this.newHeight - (headHeight + cellSpacing * 2) - (footHeight + cellSpacing * 2)) + 'px';

 

       };

 

       this.tableEl = tableEl;

       this.scrollWidth = 16;

       this.originalHeight = this.tableEl.clientHeight;

       this.originalWidth = this.tableEl.clientWidth;

      this.newHeight = parseInt(tableHeight);

       this.newWidth = tableWidth ? parseInt(tableWidth) : this.originalWidth;

      this.tableEl.style.height = 'auto';

       this.tableEl.removeAttribute('height');

      this.containerEl = this.tableEl.parentNode.insertBefore(document.createElement('div'), this.tableEl);

       this.containerEl.appendChild(this.tableEl);

       this.containerEl.style.height = this.newHeight + 'px';

       this.containerEl.style.width = this.newWidth + 'px';

      var thead = this.tableEl.getElementsByTagName('thead');

       this.thead = (thead[0]) ? thead[0] : null;

      var tfoot = this.tableEl.getElementsByTagName('tfoot');

       this.tfoot = (tfoot[0]) ? tfoot[0] : null;

      var tbody = this.tableEl.getElementsByTagName('tbody');

       this.tbody = (tbody[0]) ? tbody[0] : null;

      if (!this.tbody) return;

      if (document.all && document.getElementById && !window.opera) this.initIEengine();

       if (!document.all && document.getElementById && !window.opera) this.initFFengine();

 }

到此就可以实现表格的内容的滚动效果了!


 

 

 

阅读(1373) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~