jQuery数据显示插件整合实现代码


Posted in Javascript onOctober 24, 2011
显示表格数据会涉及到一些东西,如字段显示隐藏,数据状态,分页之类。

由于我们公司的产品涉及到很多的表格数据显示,而且每张表的字段数都很多,在工作过程中(几任同仁的努力),整合出一套自认为较为轻巧的方案。如图:jQuery数据显示插件整合实现代码

其中涉及到的插件主要有:
jQuery.columnmanager.expand.js(扩展columnmanager)
jQuery.dropbox.js(自已写的)
jQuery.pager.expand.js(扩展pager) 
jQuery.cookie.js
 其中pager.expand.js,dropbox.js以及各插件间的整合在common.js里,代码如下:

//定义全局命名空间 
var GLOBAL = {}; 
GLOBAL.Namespace = function(str) { 
var arr = str.split("."), o = GLOBAL; 
for (var i = (arr[0] == 'GLOBAL') ? 1 : 0; i < arr.length; i++) { 
o[arr[i]] = o[arr[i]] || {}; 
o = o[arr[i]]; 
} 
} 
GLOBAL.Namespace("zyh"); 
/* 
****************************************************************** 
jQuery.pager 
****************************************************************** 
*/ 
(function($) { 
$.fn.pager = function(options) { 
var opts = $.extend({}, $.fn.pager.defaults, options); 
return this.each(function() { 
// empty out the destination element and then render out the pager with the supplied options 
$(this).empty().append(renderpager(parseInt(options.pagenumber), parseInt(options.pagecount), options.buttonClickCallback, options.rowcount)); 
// specify correct cursor activity 
//$('.pages li').mouseover(function() { document.body.style.cursor = "pointer"; }).mouseout(function() { document.body.style.cursor = "auto"; }); 
}); 
}; 
// render and return the pager with the supplied options 
function renderpager(pagenumber, pagecount, buttonClickCallback, rowcount) { 
// setup $pager to hold render 
var $pager = $('<ul class="pages"></ul>'); 
// add in the previous and next buttons 
$pager.append(renderButton('|<', pagenumber, pagecount, buttonClickCallback)).append(renderButton('<<', pagenumber, pagecount, buttonClickCallback)); 
// pager currently only handles 10 viewable pages ( could be easily parameterized, maybe in next version ) so handle edge cases 
var startPoint = 1; 
var endPoint = 6; 
if (pagenumber > 3) { 
startPoint = pagenumber - 3; 
endPoint = pagenumber + 3; 
} 
if (endPoint > pagecount) { 
startPoint = pagecount - 5; 
endPoint = pagecount; 
} 
if (startPoint < 1) { 
startPoint = 1; 
} 
// loop thru visible pages and render buttons 
for (var page = startPoint; page <= endPoint; page++) { 
var currentButton = $('<li class="page-number">' + (page) + '</li>'); 
page == pagenumber ? currentButton.addClass('pgCurrent') : currentButton.click(function() { buttonClickCallback(this.firstChild.data); }); 
currentButton.appendTo($pager); 
} 
// render in the next and last buttons before returning the whole rendered control back. 
$pager.append(renderButton('>>', pagenumber, pagecount, buttonClickCallback)).append(renderButton('>|', pagenumber, pagecount, buttonClickCallback)); 
$pager.append('<li class="pgNone">共' + pagecount + "页</li>"); 
// if (rowcount != undefined) { 
// $pager.append('<li class="pgNone">共' + rowcount + "条记录,最多显示600条</li>"); 
// } 
if (rowcount != undefined) { 
$pager.append('<li class="pgText"> ' + rowcount + '条记录 </li>'); 
} 
return $pager; 
} 
// renders and returns a 'specialized' button, ie 'next', 'previous' etc. rather than a page number button 
function renderButton(buttonLabel, pagenumber, pagecount, buttonClickCallback) { 
var $Button = $('<li class="pgNext">' + buttonLabel + '</li>'); 
var destPage = 1; 
// work out destination page for required button type 
switch (buttonLabel) { 
case "|<": 
destPage = 1; 
break; 
case "<<": 
destPage = pagenumber - 1; 
break; 
case ">>": 
destPage = pagenumber + 1; 
break; 
case ">|": 
destPage = pagecount; 
break; 
} 
// disable and 'grey' out buttons if not needed. 
if (buttonLabel == "|<" || buttonLabel == "<<") { 
pagenumber <= 1 ? $Button.addClass('pgEmpty') : $Button.click(function() { buttonClickCallback(destPage); }); 
} 
else { 
pagenumber >= pagecount ? $Button.addClass('pgEmpty') : $Button.click(function() { buttonClickCallback(destPage); }); 
} 
return $Button; 
} 
// pager defaults. hardly worth bothering with in this case but used as placeholder for expansion in the next version 
$.fn.pager.defaults = { 
pagenumber: 1, 
pagecount: 1 
}; 
})(jQuery); 
/* 
================================================================ 
//组件功能:鼠标移上指定目标弹出下拉框 -- by flowerszhong 
//参数说明: 
//target:事件对象Id 
//box:下拉框Id 
//left:以事件对象最上的坐标左偏移量,默认为0; 
//top:以事件对象最上的坐标上偏移量,默认为事件对象的高度 
//overClass:当前状态表格行保持高亮样式 
//on:弹出框是否有箭头 
//arrow:自动调节的指向箭头 
================================================================ 
*/ 
var dropbox = function(target, box, left, top, overClass, on, hasArrow) { 
var obj, b, p; 
if (typeof target == "object") 
obj = $(target); 
else 
obj = $("#" + target); 
if (typeof box == "object") 
b = $(box); 
else 
b = $("#" + box); 
p = obj.parent(); 
if (top == "undefined") top = obj.height(); 
var defaults = { 
l: left || 0, 
t: top || 0, 
overClass: overClass || "", 
on: on || "", 
hasArrow: hasArrow || "" 
}, 
offset = obj.offset(), 
w = $(window).height(), 
selectSet = function(flag) { 
//在IE6中,防止select控件遮罩下拉框 
if ($.browser.msie && $.browser.version == "6.0") { 
if (flag) { 
$("select").css("visibility", "visible"); 
} else { 
$("select").css("visibility", "hidden"); 
} 
} 
}; 
$(window).resize(function() { 
w = $(window).height(); 
offset = obj.offset(); 
}); 
$("#arrow").click(function() { 
offset = obj.offset(); 
}); 
//绑定mouseover事件 
obj.bind("mouseover", function() { 
var diff, arrow, scrollTop; 
scrollTop = $(window).scrollTop(); 
diff = w - (offset.top - scrollTop); 
if (on && diff < 145) { 
var subTop = 145 - diff; 
b.css({ "display": "block", "left": offset.left + defaults.l + "px", "top": offset.top + defaults.t - subTop + "px" }); 
if (hasArrow) { 
arrow = b.children("div")[0]; 
var arrTop = 35 + subTop; 
$(arrow).css("top", arrTop); 
} 
} else { 
b.css({ "display": "block", "left": offset.left + defaults.l + "px", "top": offset.top + defaults.t + "px" }); 
if (hasArrow) { 
arrow = b.children("div")[0]; 
$(arrow).css("top", "35px"); 
} 
} 
b.bind("mouseover", function(event) { 
$(this).show(); 
selectSet(false); 
if (overClass) { p.addClass(overClass); } 
event.stopPropagation(); //阻止事件冒泡 
}); 
b.bind("mouseout", function(event) { 
$(this).hide(); 
selectSet(true); 
if (overClass) { p.removeClass(overClass); } 
event.stopPropagation(); //阻止事件冒泡 
}); 
if (overClass) { p.addClass(overClass); } 
selectSet(false); 
}); 
//绑定mouseout事件 
obj.bind("mouseout", function() { 
b.css("display", "none"); 
selectSet(true); 
if (overClass) { p.removeClass(overClass); } 
}); 
//debugger; 
}; 
GLOBAL.zyh.dropbox = dropbox; 
/* 
================================================================ 
//功能:Toggle Column 表格自定义列通用方法,基于jquery.columnmanager组件,GLOBAL.zyh.dropbox组件 
//参数说明: 
//targetTable:表格Id 
//columnManagerArgument:jquery.columnmanager需要参数 
//btnSetColumn: 
//targetfive: 
//left: 0 
//top: 0 
================================================================ 
*/ 
GLOBAL.zyh.toggleTableColumn = function(options) { 
var defaults = { 
targetTable: '', 
columnManagerArgument: {}, 
btnSetColumn: '', 
targetfive: '', 
left: 0, 
top: 0 
} 
var settings = $.extend({}, defaults, options); 
$('#' + settings.targetTable).columnManager(settings.columnManagerArgument); 
GLOBAL.zyh.dropbox(settings.btnSetColumn, settings.targetfive, settings.left, settings.top); 
}
Javascript 相关文章推荐
javascript权威指南 学习笔记之javascript数据类型
Sep 24 Javascript
JS获取后台Cookies值的小例子
Mar 04 Javascript
JS.findElementById()使用介绍
Sep 21 Javascript
jquery和雅虎的yql服务实现天气预报服务示例
Feb 08 Javascript
基于CSS3和jQuery实现跟随鼠标方位的Hover特效
Jul 25 Javascript
原生js获取元素样式的简单方法
Aug 06 Javascript
AngularJS自定义指令实现面包屑功能完整实例
May 17 Javascript
Node.js应用设置安全的沙箱环境
Apr 23 Javascript
基于Vue的延迟加载插件vue-view-lazy
May 21 Javascript
浅谈layui框架自带分页和表格重载的接口解析问题
Sep 11 Javascript
JavaScript中CreateTextFile函数
Aug 30 Javascript
用vue写一个日历
Nov 02 Javascript
基于jquery跨浏览器显示的file上传控件
Oct 24 #Javascript
firefox下input type=&quot;file&quot;的size是多大
Oct 24 #Javascript
jquery.fileEveryWhere.js 一个跨浏览器的file显示插件
Oct 24 #Javascript
editable.js 基于jquery的表格的编辑插件
Oct 24 #Javascript
基于jquery的防止大图片撑破页面的实现代码(立即缩放)
Oct 24 #Javascript
css值转换成数值请抛弃parseInt
Oct 24 #Javascript
更优雅的事件触发兼容
Oct 24 #Javascript
You might like
网站当前的在线人数
2006/10/09 PHP
jquery获取ASP.NET服务器端控件dropdownlist和radiobuttonlist生成客户端HTML标签后的value和text值
2010/06/28 Javascript
jQuery的运行机制和设计理念分析
2011/04/05 Javascript
S2SH整合JQuery+Ajax实现登录验证功能实现代码
2013/01/30 Javascript
Jquery submit()无法提交问题
2013/04/21 Javascript
快速查找数组中的某个元素并返回下标示例
2013/09/03 Javascript
吐槽一下我所了解的Node.js
2014/10/08 Javascript
javascript限制用户只能输汉字中文的方法
2014/11/20 Javascript
Javascript函数的参数
2015/07/16 Javascript
20分钟成功编写bootstrap响应式页面 就这么简单
2016/05/12 Javascript
jQuery实现背景滑动菜单
2016/12/02 Javascript
在vue项目中使用element-ui的Upload上传组件的示例
2018/02/08 Javascript
layui的table单击行勾选checkbox功能方法
2018/08/14 Javascript
nodejs基础之buffer缓冲区用法分析
2018/12/26 NodeJs
vue+elementUI实现表单和图片上传及验证功能示例
2019/05/14 Javascript
JS实现可用滑块滑动的缓动图代码
2019/09/01 Javascript
JS实现iframe中子父页面跨域通讯的方法分析
2020/03/10 Javascript
Vue通过Blob对象实现导出Excel功能示例代码
2020/07/31 Javascript
python实现清屏的方法
2015/04/30 Python
Django查找网站项目根目录和对正则表达式的支持
2015/07/15 Python
TensorFlow安装及jupyter notebook配置方法
2017/09/08 Python
python匹配两个短语之间的字符实例
2018/12/25 Python
python顺序执行多个py文件的方法
2019/06/29 Python
基于Tensorflow一维卷积用法详解
2020/05/22 Python
Python如何绘制日历图和热力图
2020/08/07 Python
python3.7 openpyxl 在excel单元格中写入数据实例
2020/09/01 Python
Ralph Lauren法国官网:美国高品味时装品牌
2017/12/08 全球购物
澳大利亚小众服装品牌:Maurie & Eve
2018/03/27 全球购物
会计系毕业个人自荐信格式
2013/09/23 职场文书
计算机专业自荐信
2013/10/14 职场文书
视光学毕业生自荐书范文
2014/02/13 职场文书
年检委托书
2014/08/30 职场文书
机关党员三严三实心得体会
2014/10/13 职场文书
团员个人年度总结
2015/02/26 职场文书
HTML5中 rem适配方案与 viewport 适配问题详解
2021/04/27 HTML / CSS
解决mysql的int型主键自增问题
2021/07/15 MySQL