jQuery 关于ScrollableGridPlugin.js(固定表头)插件的逐步解析

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
简介:

以前写前台的时候需要用哪些效果从来都是有现成的东西拿来就用的,因为自己真的是有些懒,毫无探索精神,只重视结果,不追求过程。

这个ScrollableGridPlugin.js是从网上找到的一个具有固定表头效果的插件,使用起来灰常的简便,而且效果也是看着不错的。不过毕竟不是量身定做的,所以有的地方在自己的项目中还是要进行一点点小改动,因为实在是太喜欢这个插件了,所以第一次进到里面,看看原作者的思路和写法,然后才能知道如何去改成适合自己项目。

对于js我完全是一个非常业余的选手,下面根据自己的现状对这个插件做了分析,反正自己是搞明白怎么回事了,有分析不对的,还请高手指教。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
/*!
* This plug-in is developed for ASP.Net GridView control to make the GridView scrollable with Fixed headers.
*/
( function  ($) {
     $.fn.Scrollable =  function  (options) { //1、定义一个jQuery实例方法,也是我们调用这个插件的入口
         var  defaults = {
             ScrollHeight: 300,
             Width: 0
         };
         var  options = $.extend(defaults, options);  //2、扩展集合,如果外部没有传入ScrollHeight的值,就默认使用300这个值,如果传入,就用传入的ScrollHeight值
         return  this .each( function  () {
             var  grid = $( this ).get(0); //3、获取当前gridview控件的对象
             var  gridWidth = grid.offsetWidth; //4、获取gridview的宽度
             var  headerCellWidths =  new  Array();
             for  ( var  i = 0; i < grid.getElementsByTagName( "TH" ).length; i++) {
                 headerCellWidths[i] = grid.getElementsByTagName( "TH" )[i].offsetWidth;
             } //5、创建了一个存储表头各个标题列的宽度的数组
             grid.parentNode.appendChild(document.createElement( "div" )); //6、在文档中gridview的同级位置最后加一个div元素
             var  parentDiv = grid.parentNode; //7、gridview的父节点,是个div
 
             var  table = document.createElement( "table" ); //8、在dom中创建一个table元素
             for  (i = 0; i < grid.attributes.length; i++) {
                 if  (grid.attributes[i].specified && grid.attributes[i].name !=  "id" ) {
                     table.setAttribute(grid.attributes[i].name, grid.attributes[i].value);
                 }
             } //9、把gridview的所有属性加到新创建的table元素上
             table.style.cssText = grid.style.cssText; //10、将样式也加到table元素上
             table.style.width = gridWidth +  "px" ; //11、为table元素设置与gridview同样的宽
             table.appendChild(document.createElement( "tbody" )); //12、为table元素加一个tbody元素
             table.getElementsByTagName( "tbody" )[0].appendChild(grid.getElementsByTagName( "TR" )[0]); //13、把gridview中的第一行数据加到tbody元素中,即table里现在存着一行gridview的标题元素,同时在gridview里删除了标题这一行的元素
             var  cells = table.getElementsByTagName( "TH" ); //14、取得表格标题列的集合
 
             var  gridRow = grid.getElementsByTagName( "TR" )[0]; //15、gridview中第一行数据列的集合
             for  ( var  i = 0; i < cells.length; i++) {
                 var  width;
                 if  (headerCellWidths[i] > gridRow.getElementsByTagName( "TD" )[i].offsetWidth) { //16、如果标题格的宽度大于数据列的宽度
                     width = headerCellWidths[i];
                 }
                 else  { //17、如果标题格的宽度小于数据列的宽度
                     width = gridRow.getElementsByTagName( "TD" )[i].offsetWidth;
                 }
                 cells[i].style.width = parseInt(width - 3) +  "px" ;
                 gridRow.getElementsByTagName( "TD" )[i].style.width = parseInt(width - 3) +  "px" ; //18、将每个标题列和数据列的宽度均调整为取其中更宽的一个,-3是出于对表格的样式进行微调考虑,不是必须
             }
             parentDiv.removeChild(grid); //19、删除gridview控件(注意只是从文档流中删除,实际还在内存当中,注意27条),现在的情况是table里只有一个表头
 
             var  dummyHeader = document.createElement( "div" ); //20、在文档中再创建一个div元素
             dummyHeader.appendChild(table); //21、把表头table加入其中
             parentDiv.appendChild(dummyHeader); //22、把这个div插入到原来gridview的位置里
             if  (options.Width > 0) { //23、如果我们最初传入了一个想要的表格宽度值,就将gridWidth赋上这个值
                 gridWidth = options.Width;
             }
             var  scrollableDiv = document.createElement( "div" ); //24、再创建一个div
             gridWidth = parseInt(gridWidth) + 17; //25、在原基础上+17是因为这是一个具有滑动条的table,当出现滑动条的时候,会在宽度上多出一个条的宽度,为了使数据列与标题列保持一致,要把这个宽度算进行,17这个值也不是必须,这个可以试验着来。
             scrollableDiv.style.cssText =  "overflow:auto;height:"  + options.ScrollHeight +  "px;width:"  + gridWidth +  "px" ; //26、给具有滚动条的div加上样式,height就是我们想让它在多大的长度时出现滚动条
             scrollableDiv.appendChild(grid); //27、将gridview(目前只存在数据存在数据列)加到这个带有滚动条的div中,这里是从内存中将grid取出
             parentDiv.appendChild(scrollableDiv); //28、将带有滚动条的div加到table的下面
         });
     };
})(jQuery);

只有弄明白插件内部是怎么回事,才能知道如何去修改。

其实这里有个地方我还是不太明白,baidu之后也没能弄明白,希望明白的朋友能告诉一下,就是13和15这两个地方都用了grid.getElementsByTagName("TR")[0]);这条语句,从表面上看应该是得到的同一个tr吧?但是我通过浏览器去跟踪的时候,发现13里调用的,得到的是grid的第一个tr,就是包含th列的标题tr,15里的也是grid里的第一个tr,但是包含的是td列的第一条数据列tr。

怪就怪在执行完13后,grid里tr数少了1,就是少了包含th列的tr。我以为是appendChild方法是转移元素进行插入,而不是复制元素进行插入,但是通过查这个方法并没有明确说明是我想的那么回事。我就有些懵了。

这个插件的调用方法如下,感兴趣的朋友可以使用试试,感觉真的非常好。

1
2
3
4
5
6
7
8
9
     <script type= "text/javascript"  src= "../Scripts/PlugIn/ScrollableGridPlugin.js" ></script>
     <script type= "text/javascript" >
         jQuery(document).ready( function  () {
             jQuery( "#<%=gv_bugList.ClientID %>" ).Scrollable({
                 ScrollHeight: 400,
                 width: 500
             });
         })
     </script>









本文转自 我不会抽烟 51CTO博客,原文链接:http://blog.51cto.com/zhouhongyu1989/1436686,如需转载请自行联系原作者

目录
相关文章
|
10天前
|
JavaScript
jQuery 树型菜单插件(Treeview)
jQuery 树型菜单插件(Treeview)
33 2
|
1月前
|
JavaScript
js 解析 byte数组 成字符串
js 解析 byte数组 成字符串
51 5
|
11天前
|
JavaScript 前端开发
jQuery Growl 插件(消息提醒)
jQuery Growl 插件(消息提醒)
22 4
jQuery Growl 插件(消息提醒)
|
13天前
|
存储 JSON JavaScript
jQuery Cookie 插件
jQuery Cookie 插件
28 4
jQuery Cookie 插件
|
6天前
|
JavaScript 前端开发
JavaScript - 测试 jQuery
JavaScript - 测试 jQuery
7 0
|
6天前
|
JavaScript 前端开发
JavaScript三级联动jQuery写法
JavaScript三级联动jQuery写法
|
6天前
|
JavaScript 前端开发
JavaScript 树状菜单栏jQuery写法
JavaScript 树状菜单栏jQuery写法
|
7天前
|
JavaScript 前端开发 API
【前端基础篇】JavaScript之jQuery介绍
【前端基础篇】JavaScript之jQuery介绍
29 0
|
1月前
|
JavaScript 前端开发 API
Javaweb之javascript的BOM对象的详细解析
BOM为Web开发提供了强大的API,允许开发者与浏览器进行深入的交互。合理使用BOM中的对象和方法,可以极大地增强Web应用的功能性和用户体验。需要注意的是,BOM的某些特征可能会在不同浏览器中表现不一致,因此在开发过程中需要进行仔细的测试和兼容性处理。通过掌握BOM,开发者能够制作出更丰富、更动态、更交互性的JavaWeb应用。
21 1
|
1月前
|
自然语言处理 前端开发 JavaScript
Javaweb之javascript的详细解析
通过明确JavaScript的定位,掌握其核心概念和相关技术栈,在实现交互丰富的Web应用时,JavaScript就能够发挥它不可替代的作用。随着前后端分离趋势的推进,JavaScript在现代 Web 开发中变得更加重要,不仅限于传统的 JavaWeb 应用,而是广泛应用于各种类型的前端项目。
18 0

推荐镜像

更多