广大的读者朋友们大家好,很高兴又可以在博客中和大家分享我的开发经验了。

  此次,我准备向大家介绍一个非常好用的jQuery表格插件——jqGrid。

  如果您在实际项目中遇到web端表格展示功能的需求,又不知道到底该使用那种技术实现时,jqGrid绝对是您的不二之选。

  如果您已经决定使用jqGrid技术完成项目中表格展示功能,又苦于没有详细的使用说明迟迟不能实际开发时,本系列博客绝对是您的不二之选。

  本篇博客将为大家介绍一下内容:

  1.   jqGrid简单使用;
  2.   jqGrid常用选项具体含义简介;
  3.   jqGrid使用json数据格式,以及jsonReader和repeatitems配合使用时json格式的实际变化。

首先,为大家展示一个非常简单Demo。使用jqGrid绘制一张表格

显示效果:

HTML:

  1. ...
  2. <table id="list2"></table>
  3. <div id="pager2"></div>

JavaScript:  

  1. ...
  2. jQuery("#list2").jqGrid({
  3. url:'server.php?q=2',
  4. datatype: "json",
  5. colNames:['Inv No','Date', 'Client', 'Amount','Tax','Total','Notes'],
  6. colModel:[
  7. {name:'id',index:'id', width:55},
  8. {name:'invdate',index:'invdate', width:90},
  9. {name:'name',index:'name asc, invdate', width:100},
  10. {name:'amount',index:'amount', width:80, align:"right"},
  11. {name:'tax',index:'tax', width:80, align:"right"},
  12. {name:'total',index:'total', width:80,align:"right"},
  13. {name:'note',index:'note', width:150, sortable:false}
  14. ],
  15. rowNum:10,
  16. rowList:[10,20,30],
  17. pager: '#pager2',
  18. sortname: 'id',
  19. viewrecords: true,
  20. sortorder: "desc",
  21. caption:"JSON Example"
  22. });
  23. jQuery("#list2").jqGrid('navGrid','#pager2',{edit:false,add:false,del:false});

下面为大家详细介绍一下上面绘制表格中,jqGrid具体选项的含义。

  • url:这个参数指定了jqGrid从服务器获取数据的请求。
  • datatype:这个参数指定了jqGrid调用的数据的格式,常用格式有json,xml,local。
  • colName:这个参数指定了jqGrid每列的title,按顺序依次排列,并且可以看出实际上它就是一个字符串数组。
  • colModel:这个参数指定了jqGrid各列的具体格式,"name"指定对应数据中属性名,“index”用于列排序,“width”显然是指定列宽,“align”对齐方式,“sortable”指定是否支持排序。其实上面每一个设置基本见名知意,大家可以大胆使用。(注意:colName与colModel 需要一一对应)
  • rowNum:这个参数指定了jqGrid显示行数,默认值20。
  • rowList:这个参数指定了jqGrid可以接受的rowNum值,如[10,20,30]。实际上它也仅仅是一个数组。
  • pager:这个参数指定了jqGrid页脚显示位置。
  • sortname:这个参数指定了jqGrid默认的排序列,可以是列名也可以是数字。
  • viewrecords:这个参数设置了是否在Pager Bar显示所有记录的总数。
  • sortorder:这个参数指定了jqGrid默认排序列的默认排序方式。
  • caption:这个参数制订了jqGrid的标题,如果设置了,则将显示在Grid的Header层。

以上仅仅是最最常用的,最最简单的选项含义,jqGrid还提供了大量选项方便大家使用,如果读者朋友们需要小编会在今后的博客中专门介绍一下jqGrid选项。

相信有很多读者朋友希望了解到底jqGrid使用的json以什么样的格式呈现,下面就为大家展示一下上面表格中使用的json数据:

  1. {"page":"1","total":2,"records":"13",
  2. "rows":[
  3. {"id":"13","cell":["13","2007-10-06","Client 3","1000.00","0.00","1000.00",null]},
  4. {"id":"12","cell":["12","2007-10-06","Client 2","700.00","140.00","840.00",null]},
  5. {"id":"11","cell":["11","2007-10-06","Client 1","600.00","120.00","720.00",null]},
  6. {"id":"10","cell":["10","2007-10-06","Client 2","100.00","20.00","120.00",null]},
  7. {"id":"9","cell":["9","2007-10-06","Client 1","200.00","40.00","240.00",null]},
  8. {"id":"8","cell":["8","2007-10-06","Client 3","200.00","0.00","200.00",null]},
  9. {"id":"7","cell":["7","2007-10-05","Client 2","120.00","12.00","134.00",null]},
  10. {"id":"6","cell":["6","2007-10-05","Client 1","50.00","10.00","60.00",""]},
  11. {"id":"5","cell":["5","2007-10-05","Client 3","100.00","0.00","100.00","no tax at all"]},
  12. {"id":"4","cell":["4","2007-10-04","Client 3","150.00","0.00","150.00","no tax"]}
  13. ],
  14. "userdata":{"amount":3220,"tax":342,"total":3564,"name":"Totals:"}}

看到jqGrid实际调用的json格式以后,很多读者朋友会产生疑问。是否只有符合上面格式的json数据才能被jqGrid解析?

答案是:否定的

这里就不得不介绍一下jqGrid的一个重要的选项jsonReader,jsonReader用于设置如何解析从Server端发回来的json数据。上面表格之所以能够成功解析出来得益于,jsonReader的默认设置。

jsonReader默认设置:

  1. jsonReader : {
  2. root: "rows", // json中代表实际模型数据的入口
  3. page: "page", // json中代表当前页码的数据
  4. total: "total", // json中代表页码总数的数据
  5. records: "records", // json中代表数据行总数的数据
  6. repeatitems: true, // 如果设为false,则jqGrid在解析json时,会根据name来搜索对应的数据元素(即可以json中元素可以不按顺序);而所使用的name是来自于colModel中的name设定。
  7. cell: "cell",
  8. id: "id",
  9. userdata: "userdata",
  10. subgrid: {
  11. root:"rows",
  12. repeatitems: true,
  13. cell:"cell"
  14. }
  15. }

如果Server端返回的json数据不太符合默认设置(比如内容结构不同)那么就有必要修改这一设置。

通常jsonReader和repeatitems是配合使用的,如果repeatitems为false,json 中数据可以乱序,并且允许数据空缺。jqGrid会根据colModel中name属性和json数据对应,根据属性名称进行解析。

repeatitems为true时:

  1. ...
  2. jsonReader : {
  3. root:"rows",
  4. page: "page",
  5. total: "total",
  6. records: "records"
  7. },
  8. ...

json结构:

  1. {
  2. "page": "xxx",
  3. "total": "yyy",
  4. "records": "zzz",
  5. "rows" : [
  6. {"id" :"1", "cell" :["cell11", "cell12", "cell13"]}, // cell中不需要各列的name,但是需要与colModel一一对应
  7. {"id" :"2", "cell" :["cell21", "cell22", "cell23"]},
  8. ...
  9. ]
  10. }

repeatitems为false时:

  1. ...
  2. repeatitems: false,
  3. jsonReader : {
  4. root:"rows",
  5. page: "page",
  6. total: "total",
  7. records: "records"
  8. },
  9. ...

json结构:

  1. {
  2. "page" : "xxx",
  3. "total" : "yyy",
  4. "records" : "zzz",
  5. "rows" : [
  6. {"invid" : "1","invdate":"cell11", "amount" :"cell12", "tax" :"cell13", "total" :"1234", "note" :"somenote"}, // 数据中需要各列的name,但是可以不按列的顺序
  7. {"invid" : "2","invdate":"cell21", "amount" :"cell22", "tax" :"cell23", "total" :"2345", "note" :"some note"},
  8. ...
  9. ]
  10. }

  非常感谢大家能坚持阅读完本篇博客。

  小编深知一篇博客不能完全介绍jqGrid的众多细节,所以会在今后的博客中不断介绍jqGrid的其他细节。

  小编希望可以通过博客将自己在jqGrid使用时遇到的各种各样的问题和解决方案分享给广大读者朋友们,希望可以帮助大家快速学习jqGrid,避免在不必要的细节上浪费大量时间。

  另外如果有读者朋友和小编一样对jqGrid十分偏爱,可以在评论区和小编一起讨论jqGrid的许许多多优缺点,并一起讨论相关解决方案。

  

  ***************************

  非常感谢读者朋友们对小编的支持,小编非常开心可以和大家分享我的开发经验。

  如果我的经验可以帮助到读者朋友们,是小编最大的动力和荣幸。

  大连理工大学

  2014-10-17 11:26:01

  ***************************

jqGrid使用经验分享(一)——jqGrid简单使用、json格式和jsonReader介绍的更多相关文章

  1. 简单创建json格式文件

    简单创建json格式文件 核心就两点: addProperty 添加属性(也就是加键值对) add是添加 另外的object对象 然后直接toString()输出 核心代码如下; public cla ...

  2. Json格式循环遍历,Json数组循环遍历

    Json格式数据如何遍历,这里我们可以用for..in实现 例如最简单的json格式 , 'handsome' : 'yes' }; for( var key in json1 ){ console. ...

  3. Web jquery表格组件 JQGrid 的使用 - 4.JQGrid参数、ColModel API、事件及方法

    系列索引 Web jquery表格组件 JQGrid 的使用 - 从入门到精通 开篇及索引 Web jquery表格组件 JQGrid 的使用 - 4.JQGrid参数.ColModel API.事件 ...

  4. 使用基于Android网络通信的OkHttp库实现Get和Post方式简单操作服务器JSON格式数据

     目录 前言 1 Get方式和Post方式接口说明 2 OkHttp库简单介绍及环境配置 3 具体实现 前言 本文具体实现思路和大部分代码参考自<第一行代码>第2版,作者:郭霖:但是文中讲 ...

  5. 金蝶随手记团队分享:还在用JSON? Protobuf让数据传输更省更快(实战篇)

    本文作者:丁同舟,来自金蝶随手记技术团队. 1.前言 本文接上篇<金蝶随手记团队分享:还在用JSON? Protobuf让数据传输更省更快(原理篇)>,以iOS端的Objective-C代 ...

  6. 简单的 JSON 对象进行深拷贝最简单的方法

    var json = { a: 123, b: '456' }; var json2 = JSON.parse(JSON.stringify(json)); 只需要先使用 JSON.stringify ...

  7. 简单的分页存储过程,Json格式日期转换为一般日期

    简单的分页存储过程 CREATE PROC Paged @pageIndex INT, @pageCount INT OUTPUT, @pageSize INT AS DECLARE @count I ...

  8. 超简单的处理JSON格式和JSON数组格式的String

    现在网站上有不少处理JSON格式的工具类,但是我找了一天,发现大都是需要编写相应对象类来进行处理,比较麻烦,比如:Gson,json-lib.Gson,json-lib这些处理那些接口之类的参数名字和 ...

  9. 简单实体Json序列化(输出JSON的属性可变)

    简单实体Json序列化(输出JSON的属性可变) 一.先看效果 可以看出 , 我们在序列化一个对像时, 只给出了 我们想要 输出的两个字段名,  实际实体有5个属性, 经过可变属性序列化后的JSON ...

随机推荐

  1. C#MVC中创建多模块web应用程序

    当一个应用程序有越来越多的子模块后,应用程序将变得越来越大,复杂度也越来越高,应用程序也越来越难维护.如果把每个子模块,独立分成不同的web应用程序,则这个项目将易于维护.关于这个的好处,我也描述得不 ...

  2. 【71.76%】【codeforces 732A】Buy a Shovel

    time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...

  3. ServletContextListener接口用法

    ServletContextListener接口用于tomcat启动时自动加载函数,方法如下: 一.需加载的类必须实现ServletContextListener接口. 二.该接口中有两个方法必须实现 ...

  4. docker入门3:基础操作(2)

    -- 容器删除 docker rm CONTAIN_ID|CONTAIN_NAME -- 镜像删除 docker rmi IMAGE_ID|IMAGE_NAME -- 进入容器 docker exec ...

  5. hdu1845 Jimmy’s Assignment --- 完整匹配

    意甲冠军: 它需要一个特殊的图,以找到最大匹配.该图的特征是:无向图,度的每个节点3.这是一个双边连接组件(the graph is 2-edge-connected (that is, at lea ...

  6. Android 异步更新UI----handler+thread

    android应用是单线程模式的. 单线程模式需要记住两条: 一.防止UI线程阻塞 二.确保只在UI线程中访问Android UI工具包 在开发Android应用时必须遵守单线程模型的原则:Andro ...

  7. 电讯“情趣me”为什么命途多舛?

        古人有句话叫做战争"鼓作气,再而衰,三而竭",意思是打仗必须"一气呵成".才干发挥最大实力,取得最好的战绩.所谓商场如战场,经商也是如此,近期,中国电信 ...

  8. C# WPF 仿网易云音乐(PC)Banner动画控件

    在自定义用户控件内添加3个border(左.中.右,以下分别简称为:b1.b2.b3),对border进行缩放和移动动画.往右切换时b1放大平移到b2的位置,b2缩小平移到b3的位置,b3平移到b1的 ...

  9. 创建网站 并未网站指定ftp用户

    这里有个视频 前10分钟可以参考 在windows server2008 r2上面安装iis 带ftp服务 :http://v.youku.com/v_show/id_XMjUyMTE1MTI0NA= ...

  10. 简明Python3教程 8.控制流

    简介 迄今为止我们见到的所有程序总是含有一连串语句并且python忠实的顺序执行它们. 那么如何改变它们的执行顺序呢?例如你希望程序根据不同情况作出不同反应,按照当前时间分别 打印出’Good Mor ...