热门标签 | HotTags
当前位置:  开发笔记 > 前端 > 正文

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 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 = $('
    ');
    // 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 = $('
  • ' + (page) + '
  • ');
    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('
  • 共' + pagecount + "页
  • ");
    // if (rowcount != undefined) {
    // $pager.append('
  • 共' + rowcount + "条记录,最多显示600条
  • ");
    // }
    if (rowcount != undefined) {
    $pager.append('
  •  ' + rowcount + '条记录 
  • ');
    }
    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 = $('
  • ' + buttonLabel + '
  • ');
    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编程能力。 ... [详细]
    • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
    • 本文介绍了一段使用jQuery实现的用户注册页面表单验证代码,适用于前端开发人员学习和参考。该示例结合了HTML、CSS和JavaScript,确保用户输入的数据格式正确。 ... [详细]
    • 基于JQuery实现的评分插件
      本文介绍了一个使用JQuery创建的交互式评分控件。当用户将鼠标悬停在星星上时,左侧的星星会变为实心,右侧保持空心,并显示对应的评分等级;移开鼠标后,所有星星恢复为空心状态。 ... [详细]
    • Spring Boot 中静态资源映射详解
      本文深入探讨了 Spring Boot 如何简化 Web 应用中的静态资源管理,包括默认的静态资源映射规则、WebJars 的使用以及静态首页的处理方法。通过本文,您将了解如何高效地管理和引用静态资源。 ... [详细]
    • 一个登陆界面
      预览截图html部分123456789101112用户登入1314邮箱名称邮箱为空15密码密码为空16登 ... [详细]
    • 深入理解Tornado模板系统
      本文详细介绍了Tornado框架中模板系统的使用方法。Tornado自带的轻量级、高效且灵活的模板语言位于tornado.template模块,支持嵌入Python代码片段,帮助开发者快速构建动态网页。 ... [详细]
    • 深入理解Cookie与Session会话管理
      本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
    • 本文介绍如何在 Xcode 中使用快捷键和菜单命令对多行代码进行缩进,包括右缩进和左缩进的具体操作方法。 ... [详细]
    • 本文详细介绍了如何使用Python编写爬虫程序,从豆瓣电影Top250页面抓取电影信息。文章涵盖了从基础的网页请求到处理反爬虫机制,再到多页数据抓取的全过程,并提供了完整的代码示例。 ... [详细]
    • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
    • 探讨如何在职业生涯中脱颖而出,研究表明刻意练习而非单纯的经验或天赋是关键。文章分析了为什么一些人即使有多年经验也未能成为专家,而另一些人则能在短时间内达到卓越水平。 ... [详细]
    • 本文详细介绍了W3C标准盒模型和IE传统盒模型的区别,探讨了CSS3中box-sizing属性的使用方法及其在布局中的重要性。通过实例分析,帮助读者更好地理解和应用这一关键概念。 ... [详细]
    • 在Linux系统中配置并启动ActiveMQ
      本文详细介绍了如何在Linux环境中安装和配置ActiveMQ,包括端口开放及防火墙设置。通过本文,您可以掌握完整的ActiveMQ部署流程,确保其在网络环境中正常运行。 ... [详细]
    • 本文详细介绍了如何使用jQuery防止事件冒泡,确保子元素的点击事件不会触发父元素或祖先元素的相应事件。通过具体的代码示例和解释,帮助开发者更好地理解和应用这一技术。 ... [详细]
    author-avatar
    苏黎世的风景
    这个家伙很懒,什么也没留下!
    PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
    Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有