jQuery表格插件GridManager.2.0(原listManager.js)

所属分类:UI-图表

 50751  407  查看评论 (19)
分享到微信朋友圈
X
jQuery表格插件GridManager.2.0(原listManager.js) ie兼容10

GridManager.js

快速、灵活的对Table标签进行实例化,让Table标签充满活力。


更新时间:2018/6/25 下午1:15:51

更新说明:

1.增加配置参数

2.样式更新


更新时间:2017/2/6 上午10:44:34

更新说明:

1.修复了部分BUG;

2.优化代码结构

3.增加单元测试

4.样式优化


使用需知

下载时请下载release版本 -v2.0为jquery版本 -原生版本正在开发中

实现功能

GridManager.js可快速的对table标签进行实例化,实例化后将实现以下功能:

  • 宽度调整: 表格的列宽度可进行拖拽式调整

  • 位置更换: 表格的列位置进行拖拽式调整

  • 配置列: 可通过配置对列进行显示隐藏转换

  • 表头吸顶: 在表存在可视区域的情况下,表头将一下存在于顶部

  • 排序: 表格单项排序或组合排序

  • 分页: 表格ajax分页,包含选择每页显示总条数和跳转至指定页功能

  • 用户偏好记忆: 记住用户行为,含用户调整的列宽、列顺序、列可视状态及每页显示条数

  • 分页、排序、刷新时自动进行数据加载,且提供相应的before、after事件

  • 序号: 自动生成序号列

  • 全选: 自动生成全选列

  • 导出: 当前页数据下载,和仅针对已选中的表格下载

  • 右键菜单: 常用功能在菜单中可进行快捷操作

安装命令

npm install GridManager

引入方式

<link rel="stylesheet" type="text/css" href="/node_modules/GridManager/dist/css/GridManager.css"/>
<script type="text/javascript" src="/node_modules/GridManager/dist/js/GridManager.js"></script>

如果不想引入CSS文件,可以通过配置项basePath与autoLoadCss两个参数进行设置,让插件自动引入CSS,示例如下:

$('table').GM({
    basePath:'/node_modules/GridManager/dist/',  //当前JS文件所在的路径
    autoLoadCss: true                          //采用自动加载CSS机制
});

浏览器兼容

-Firefox, Chrome,IE10+ -这里提一下为什么不支持低版本: 使用表格插件的大都是管理平台或系统,通常都是会进行浏览器指定,所以设计之初就没有考虑这个方面.

调用方式

    <table grid-manager="test"></table>
    $('table[grid-manager="test"]').GM({
        supportRemind: true
        ,i18n:'zh-cn'
        ,textConfig:{
            'page-go': {
                'zh-cn':'跳转',
                'en-us':'Go '
            }
        }
        ,disableCache:false
        ,disableOrder:false
        ,supportSorting: true
        ,isCombSorting: true
        ,sortDownText: 'up'
        ,sortUpText: 'down'
        ,supportDrag:true
        ,supportAjaxPage:true
        ,ajax_url: 'data/test.json'
        ,ajax_type: 'POST'
        ,pageSize:30
        ,query: {ex: '用户自定义的查询参数,格式:{key:value}'}
        ,columnData: [{
                key: 'name',
                remind: 'the username',
                sorting: 'up',
                width: '200px',
                text: 'username'
            },{
                key: 'age',
                remind: 'the age',
                width: '200px',
                text: 'age'
            },{
                key: 'createDate',
                remind: 'the createDate',
                sorting: 'down',
                width: '200px',
                text: 'createDate'
            },{
                key: 'info',
                remind: 'the info',
                text: 'info'
            },{
                key: 'operation',
                remind: 'the operation',
                sorting: '',
                width: '200px',
                text: 'operation',
                template: function(operation, rowObject){  //operation:当前key所对应的单条数据;rowObject:单个一行完整数据
                    return '<a href=javascript:alert("这是一个按纽");>'+operation+'</a>';
                }
            }
        ]
    });

数据格式 

{
    "data":[{
            "name": "baukh",
            "age": "28",
            "createDate": "2015-03-12",
            "info": "野生前端程序",
            "operation": "修改"
        },
        {
            "name": "baukh",
            "age": "28",
            "createDate": "2015-03-12",
            "info": "野生前端程序",
            "operation": "修改"
        },
        {
            "name": "baukh",
            "age": "28",
            "createDate": "2015-03-12",
            "info": "野生前端程序",
            "operation": "修改"
        }
    ],
    "totals": 1682
   }

常见问题解答

1.数据在渲染前就已经存在,如何配置?

可以通过参数ajax_data进行配置,如果存在配置数据ajax_data,将不再通过ajax_url进行数据请求,且ajax_beforeSend、ajax_error、ajax_complete将失效,仅有ajax_success会被执行.

2.如何在数据请求中增加筛选条件?

可以通过参数query进行配置,该参数会在GirdManager实例中一直存在,并且可以在筛选条件更改后通过$('table').GM('setQuery')方法进行重置.

3.开发中想查看当前的GirdManager实例中的数据怎么实现?

通过$('table').GM('get')方法可以获得完整的GirdManager对象;通过$('table').GM('getLocalStorage')可以获得本地存储信息.

4.实例化出错怎么办?

查看DOM节点是否为<table grid-manager="test"></table>格式

查看配置项columnData中key值是否与返回数据字段匹配.

5.后端语言返回的数据格式与插件格式不同怎么处理?

可以通过参数[dataKey:ajax请求返回的列表数据key键值,默认为data][totalsKey:ajax请求返回的数据总条数key键值,默认为totals]进行配置.

6.表格样式未加载成功,怎么处理?

插件采用两种样式加载机制,一种是通过用户自动link,一种是通过配置参数autoLoadCss=true与参数basePath来进行自动加载.出现样式错误的情况,多半是由于采用自动加载机制,但参数basePath未配置正确导致的.

排错重点为参数:autoLoadCss(是否自动加载CSS文件),basePath(当前基本路径,用于css自动加载样式文件)

如果不能确定basePath,建议将autoLoadCss设置为false,通过link手动进行加载.

7.表格th中的文本显示不全

查看配置项[columnData]中的width, 将该值提高或不进行设置由插件自动控制. 如果还为生效,那是由于当臆实例开始了记忆功能,解决方法为:将localStorage中包含与当前表格grid-manager名称对应的项清除,或使用localStorage.clear()将本地存储全部清除.

8.想清除当前记忆的宽度及列位置时怎么办?

可使用clear方法,调用方式:$('table').GM('clear');

相关插件-图表

支持ie8的圆形统计比例图

动态统计,支持ie8以及以上版本的ie浏览器,其他的浏览器
  图表
 53513  421

Web动态热图插件heatmap.js

Web动态热图插件heatmap.js,可用于监控设备运行状态。
  图表
 29220  278

jquery 表行列固定

支持表格行列固定和排序兼容所有浏览器
  图表
 64505  497

echarts使用示例

静态使用echarts样式,仅作参考
  图表
 60965  503

讨论这个项目(19)回答他人问题或分享插件使用方法奖励jQ币 评论用户自律公约

    hyc643300 0
    2023/3/11 17:07:57
    这个和H-UI前端框架不能一起使用吗? 回复
    半城烟沙 0
    2022/10/21 15:02:02
    您好,作者,我用了您的插件后,并未实现分页的功能,第一页就是全部的数据,第二页也是全部数据 回复
    0
    2019/7/18 17:26:24
    为什么我后台取不到query里面的参数啊,分页参数也取不到
        拭目以待0
        2019/11/28 14:16:29
        可以把详细问题发到github上,jq22我不常上。
    回复
    小小66 0
    2018/1/16 19:01:52

    这个插件只支持字符串排序吗????

    回复
    小小66 0
    2018/1/15 11:32:13

    为什么排序结果不正确???

        拭目以待1
        2019/1/10 17:48:11
        排序功能是需要接口支撑的,你触发排序后看一下请求参数。
    回复
    -果冻-- 0
    2017/11/21 15:12:13

    不支持IE

        徐磊0
        2018/8/29 16:59:27
        不支持IE 这么狠尴尬
    回复
    别说话 0
    2017/6/5 13:31:49

    问下为什么ie下显示得都是空白啊

    回复
    提拉米苏忒亚 0
    2017/4/12 10:01:02

    请问ajax_data怎么使用啊,数据已经存在了,不能该数据格式的

    回复
    拭目以待 0
    2017/3/20 16:56:47

    GridManager新版首页

    http://www.lovejavascript.com/GridManager/index.html

    回复
    狼灰灰 0
    2017/2/28 14:52:08

    大神,我问一下,为什么放到IE浏览器中,就“SCRIPT438:对象不支持“remove”属性或方法”  GridManager.min.js(1,17568)报这个错误!

    回复
😃
  • 😀
  • 😉
  • 😥
  • 😵
  • 😫
  • 😘
  • 😡
  • 👍
  • 🌹
  • 👏
  • 🍺
  • 🍉
  • 🌙
  • 💖
  • 💔
😃
  • 😀
  • 😉
  • 😥
  • 😵
  • 😫
  • 😘
  • 😡
  • 👍
  • 🌹
  • 👏
  • 🍺
  • 🍉
  • 🌙
  • 💖
  • 💔
取消回复