强大的JQuery的插件jqGrid
更新时间:2023-07-18 19:11:01 阅读量: 实用文档 文档下载
希望这个帮助文档能对大家学习jQuery的插件jqGrid带来帮助(在个人的使用过程中不断更新),希望大家提出意见。
jQuery 的jqGrid包 现在已经更新到了3.8了 ,但是其中的主要应用是不会有太大的改动的,希望这个帮助文档能对jQuery插件的学习有所帮助。
jqGrid包说明:
jquery.js is the jQuery library,
jquery.jqGrid.js 主单元,包含的功能取决您的选择
grid.basic.js 主插件 其他插件包依赖于该插件正常运行
grid.custom.js Grid高级插件功能包
grid.formedit.js 用于表格编辑、增加、删除功能
grid.inlinedit.js 线条编辑
grid.subgrid.js 一个处理表格的插件
grid.postext.js 一个可以用来操作post数据的包
jqModal.js 模态对话框的编辑
jqDnR.js 可拖拉的表格编辑
themes 包含gird需要的样式表
一、 功能描述:
jqGrid包主要用于将需要展示的数据动态的展示在页面的上,即动态画出表格,并封装了增、删、改、查、分类显示、在线编辑修改等功能。
二、 关键使用说明:
1、 导入jqGrid包,在首页属性里面添加如下包的信息
<link rel=\"stylesheet\" type=\"text/css\" media=\"screen\"
href=\"/SedSoft/jqGrid/themes/basic/grid.css\">
<link rel=\"stylesheet\" type=\"text/css\" media=\"screen\"
href=\"/SedSoft/jqGrid/themes/jqModal.css\">
<script type=\"text/javascript\" src=\"/sedsoft/jqGrid/jquery.js\" > </script>
<script type=\"text/javascript\" src=\"/sedsoft/jqGrid/jquery.jqGrid.js\" ></script>
<script type=\"text/javascript\" src=\"/sedsoft/jqGrid/js/jqModal.js\" ></script>
<script type=\"text/javascript\" src=\"/sedsoft/jqGrid/js/jqDnR.js\" > </script>
注:由于加载js包 会耗费大量资源,建议动态加载这些js包,优化页面初始化效
率。 2、 在页面上需要添加表格的地方, 增加
<table id="list" class="scroll"></table>
<div id="pager" class="scroll" style="text-align:center;"></div>
</body>
list表格id,pager为表格导航条id 三、 写jqGrid函数
jQuery(document).ready(function(){
jQuery("#list").jqGrid({
',
datatype: 'xml',
希望这个帮助文档能对大家学习jQuery的插件jqGrid带来帮助(在个人的使用过程中不断更新),希望大家提出意见。
mtype: 'GET',
colNames:['Inv No','Date', 'Amount','Tax','Total','Notes'],
colModel :[
{name:'invid', index:'invid', width:55},
{name:'invdate', index:'invdate', width:90},
{name:'amount', index:'amount', width:80, align:'right'},
{name:'tax', index:'tax', width:80, align:'right'},
{name:'total', index:'total', width:80, align:'right'},
{name:'note', index:'note', width:150, sortable:false} ],
pager: jQuery('#pager'),
rowNum:10,
rowList:[10,20,30],
sortname: 'id',
sortorder: "desc",
viewrecords: true,
imgpath: 'themes/basic/images',
caption: 'My first grid'
});
});
以上代码基本可以将要展示的表格展示出来了,现在对一些属性说明:
jQuery(“#list”).jqGrid list为将要显示表格的table 的id
altRows : 设置表格显示斑马条纹属性,默认值为true
caption: 定义表格标题名
cellEdit: 设置表格单元是否可以编辑,默认值为true,详见cellEdit介绍
cellsubmit: 决定cell容器如何被保存,使用’remote’或者‘clientArray’,详见cellEdit cellurl: 处理cell编辑的url路径,默认值为空
datatype : 从后台展示的数据格式,有xml、 json等
mtype: 数据传递的方式,有get 和post两种
editurl: 定义inline和form 编辑的后台处理url
Expandcolumn: 在定义treeGrid情况下,指明那一列用来伸展树
forceFit:设置表格在被拖动时自动调整大小以不破坏表格整体布局,注:该属性和 shrinkToFit不能同时使用
gridstate: 设置通用表格在使用hiddengrid属性时,hidegrid的值,可以是:’visible’
或’hidden’默认为visible
shrinkToFit
loadonce: 如果该值设置为true则表格数据仅加载一次,在第一次请求之后数据信息自动转变为客户端处理,pager导航条上的函数都不可用。
loadtext: 在请求数据时显示字幕,默认值为:Loading….
colNames:要显示数据表格的列名 ,需要在前台定义好表格列名
colMode: 对要展示的每列值属性进行定义,最常用的有:
align: 定义表格对齐方式,默认值为left
希望这个帮助文档能对大家学习jQuery的插件jqGrid带来帮助(在个人的使用过程中不断更新),希望大家提出意见。
datefmt:日期格式,默认值为:Y-M-d
editable:定义field是否可编辑,该属性用于inline和form编辑,默认值为false
editrules:editrules:{edithidden:true,//如果为true,则该列在添加和编辑时被隐藏
required:true,//如果为true,则该列表格不能为空
number:true,//true时表格必须为数字型
integer:true,//true时,表格数字为整形
minValue:val,//设置数字最小值与最大值
maxValue:val,
email:true}//验证是否为email
edittype:定义编辑类型:text,texttarea,select,checkbox,passworad
hidedlg: 为true时,该列不会显示在表格对话框中
hidden: 定义列在初始化时是否被隐藏
index: 定义索引名
name: 定义属性名,必填项
resizable: 定义列是否可调整大小
index: 定义列id
width: 宽度
align: 对齐方式
pager: 导航条要展示的位置
rowNum: 默认的每页显示记录数
rowList: 可选的每页显示数
viewrecords: 是否设置表格可选,为true是可选,但此时表格不可编辑,只有在false是才可以编辑
imgpath: 图片路径
注:以上属性并不会全部同时出现在jqGrid表格设置里,jqGrid设计了灵活多变的不同组合来展示表格不同的功能。在以后的实际应用里,将对重点属性的组合和分配进行说明。
四、 增加、删除、修改操作的实现
1) 增加
jqGrid包自身封装了相当完善的操作事件,
jQuery("#list").navGrid('#pager',
{
refresh: true,
edit: true,
add: true,
del: true,
search: true ,
position:"right"})
将上面一段代码,添加到jqGrid({})后面,refresh等参数,均设置为true,则
导航条上即可显示出五个按钮,刷新、编辑、增加、查找等,position设置这些按钮在导航条上的位置。
editurl: pathname+'/xmlTableEdit?openagent&oper=edit', //设置添加、更新的url
希望这个帮助文档能对大家学习jQuery的插件jqGrid带来帮助(在个人的使用过程中不断更新),希望大家提出意见。
这段代码是编辑、增加、查找等功能执行的代码,写在url后面方便查找。对于这些定义的功能,每个操作传递过去的editurl是不一样的,oper分别是edit ,add,search、等。之后传递的是操作后,数据变化的参数。
当然,我们很多时候需要自己定义一些事件,jqGrid有一个添加按钮的函数,可以方便的添加我们想要的任何功能按钮
jQuery("#list").navGrid('#pager',
{
refresh: true,
edit: true,
add: true,
del: true,
search: true ,
position:"right"}
).navButtonAdd(
'#pager',
{
caption:"Del",
buttonimg:"/SedSoft/jqGrid/themes/basic/images/folder.png",
onClickButton: function(){ //执行删除行操作
// var gr = jQuery("#list").getGridParam("selarrrow");
var gr=chooseid;
if( gr != null&gr!="" ) {
jQuery("#list").delGridRow(gr,{
afterSubmit: function(xhr,postdata){
alert ('After Submit: ' + postdata);
return [true]},
url: pathname +'/xmlTableEdit?openagent&oper=del' //执行删除代理rul
});
} else {
alert("Please Select Row to delete!");
};},position:"last"
})
上面这段代码就添加了一个删除按钮,并获得选中的id数组,并通过url代理去处理该操作。
事实上,通过.navButtonAdd()函数可以添加任何我们想要的按钮,而该函数里面属性分别定义按钮出现的位置’#pager’,按钮标题字符’caption’,按钮图标路径’buttonimg’,点击按钮的onClickButton事件,在事件里面可以写任何你想要的js代码,以满足你的需求。position属性定义了按钮显示的位置。
除了这种直接添加按钮和事件的方法外,jqGrid还提供了重写和替换部分功能函数的能力。举例编辑功能说明。
四、jqGrid的修改编辑功能
jqGrid定义了三种可以用于修改和编辑表格数据的方法,分别是cellEdit、inline Edit、
希望这个帮助文档能对大家学习jQuery的插件jqGrid带来帮助(在个人的使用过程中不断更新),希望大家提出意见。
rowEdit
分别对应单元格编辑、在线行编辑、以对话框式的行编辑。以下将分别简单介绍这三种编辑方法和用法。
(一) cellEdit:
单元格编辑支持键盘操作,当选中某一单元格时,可以按上下、左右来切
换选中
如果单元格可编辑,当我们按下Enter键或鼠标点击其他键时cell编辑后将被
保存,除非我们按下Esc键
当cell被编辑过后,cell编程’dirty’数据,这时候在左上角会显示出一个红色
标记
当我们点击可编辑的cell时,我们可以直接进入编辑状态
properties:
1、有三个属性来设置cellEdit:
cellEdit:当为true时,cell才可编辑,此时Multiselect(设置选择多行)则不可用,
onSelectRow函数不可用
cellsubmit:定义cell容器在那里被保存,’remote’或’clientArray’。如果是’remote’
则数据会立刻通过cellUrl用Ajax方式传递到后台去处理,传递格式为:
{id:rowed,mycell:cellvalue}
cellurl: 设置cell编辑的url
注意:在collmodel里对列属性进行定义的editrules{}里,所有的设置对cellEdit、
inline、rowEdit均适用。
2、cellEdit编辑的几种事件
afterEditCell(rowed,cellname,value,iRow,iCol)
afterSaveCell(rowed,cellname,value,iRow,iCol)
afterSubmitCell(serverresponse,rowed,cellname,value,iRow,iCol)
beforeEidtCell(rowed,cellname,value,iRow,iCol)
beforeSaveCell(rowed,cellname,value,iRow,iCol)
beforeSubmitCell(rowed,cellname,value,iRow,iCol)
errorCell(serverresponse,statur)
onSelectCell(rowed,celname,value,iRow,iCol)
这些事件在实际应用中拿出部分进行组合应用即可,其中onSelectCell只能应用于
不可编辑的单元格
3、举例说明
cellurl: pathname+'/xmlSaleTableEdit?openagent&oper=edit', //定义编辑cellEdit rul和
editUrl不同,需要单独设置
cellEdit: true, //cell编辑时,此属性必须为true
afterEditCell: function(rowid,cellname,value,iRow,iCol){
var zk= jQuery("#list").getCell(rowid,"N_JinEr");//获取某一单元格的值
jQuery("#list").setCell(rowid,"N_JinEr",9000,{color:'red','text-align':'center'});
},
afterSubmitCell:function(serverrepsponse,rowid,cellname,value,iRow,iCol){
var text=serverrepsponse.responseText;
希望这个帮助文档能对大家学习jQuery的插件jqGrid带来帮助(在个人的使用过程中不断更新),希望大家提出意见。
var arr = text.split(";");
if(arr[0].indexOf("true")!=-1){
var num = parseFloat(arr[1]);
jQuery("#list").setCell(rowid,"N_JinEr",num ,{color:'red','text-align':'center'});
}
},
以上代码展示了cellEdit设置需要的代码。cellEdit功能的实现只需要设置cellEdit为true,并设置cellurl在后台写处理数据的程序即可。而要满足功能上的需要,还需要添加afterEditCell等事件。
afterSubmitCell:提交完成后事件,serverrepsponse从后台返回数据,rowid选中行id, cellname 单元格name属性在colModel里设置,value cell的值,iRow index of the row,iCol the index of the column
jQuery("#list").setCell(rowid,"N_JinEr",num ,{color:'red','text-align':'center'}//设行id为rowid,列名为’N_JinEr’的单元格值为num,样式设置为{color:'red','text-align':'center'}。
afterSubmitCell处理了cellEdit编辑后,从后台取回数据并处理单元格值的过程,在实际情况下根据需要添加不同事件即可。
(二) inlineEdit:
editurl:pathname+'/xmlTableEdit?openagent&oper='+oper+'&showView='+showView+'&formName='+formName+'&punid='+unid, //设置添加、更新的url /* //以下参数根据需要添加, /* oper: 操作类型,edit 编辑、 del 删除、
showView: 操作视图名,即表格展示的试图
formName: 操作标识符,区分不同表单的不同操作
punid: 主文档id
*/
ultiselect: false, //选择行属性inlineEdit时不能设置多选行
onSelectRow: function(id){
chooseid=id;
if(id && id!==lastsel2){
jQuery('#list').restoreRow(lastsel2); //选中不同表格id变化 jQuery('#list').editRow(id,true,oneditfunc,aftersavefunc); //表格编辑函数
lastsel2=id;
};
// 表格编辑时触发函数,一般无用可以为空
function oneditfunc(id){
};
//格编辑保存后执行函数,可以用来处理相关事件
function aftersavefunc(id,res){
jQuery("#list").trigger("reloadGrid");
changeValueafEdit(showView,unid);
};
},
// 重写编辑验证提示
希望这个帮助文档能对大家学习jQuery的插件jqGrid带来帮助(在个人的使用过程中不断更新),希望大家提出意见。
jQuery.jgrid.edit = {
editCaption: "编辑记录",
bSubmit: "提交",
bCancel: "退出",
processData: "处理中...",
width:400,
dodal:true,
msg: {
required:"Field is required",
number:"请输入数字!",
minValue:"数值应大于 ",
maxValue:"数值应小于"
}
};
$.extend($.jgrid.edit,{Edit:'修改'});
五、xml数据格式的解释
XML Data
jqGrid解释数据的方式有三种:xml、json、xmlString,我们使用xml这种方式来处理。Xml的格式和作用,这里不做说明,有兴趣的可以自己到网上查。
xmlReader :
{ root: "rows",
row: "row",
page: "rows>page",
total: "rows>total",
records : "rows>records",
repeatitems: true,
cell: "cell",
id: "[id]",
userdata: "userdata",
subgrid: { root:"rows", row: "row", repeatitems: true, cell:"cell" }
}
上面一段代码,放在jqGrid里面,作为对后台传送xml数据格式的解释方式。标准的jqGrid 支持的xml格式如下所示:
<?xml version='1.0' encoding='utf-8'?>
<root>
<rows> -----root:rows
<row> -----row:row
<cell>sss</cell> ------cell:cell
<cell>sss</cell>
<cell>sss</cell>
<cell>sss</cell>
<cell>sss</cell>
希望这个帮助文档能对大家学习jQuery的插件jqGrid带来帮助(在个人的使用过程中不断更新),希望大家提出意见。
<cell>sss</cell>
<cell>sss</cell>
</row>
<row>
<cell>sss</cell>
<cell>sss</cell>
<cell>sss</cell>
<cell>sss</cell>
<cell>sss</cell>
<cell>sss</cell>
<cell>sss</cell>
</row>
</rows>
</root>
如果xml格式发生变化,则xmlReader里的数据做相应修改即可。
page: "rows>page",
total: "rows>total",
records : "rows>records",
repeatitems: true,
这几行代码的作用在于,定义分页的条件,使页面正确显示数据和分页。最后一个repertitems是设置xml格式里的cell是否可以重复一样。
六、一些操作函数
jQuery("#grid_id").trigger("reloadGrid"); 刷新表格
jQuery("#grid_id").getGridParam('selarrrow'); 获取选择表格的id 多选的
jQuery("#grid_id").getGridParam('selrow'); 获取选中表格id 单选
//设置不可编辑的单元格被选中后触发的事件
onSelectCell:function(rowid,celname,value,iRow,iCol){
var gg= jQuery("#list").getGridParam("selrow");
var gr= jQuery("#list").getCell(gg,"N_DanJia");
if(gr<100){
N_DanJia:1000;
};
},
beforeSubmitCell : function(rowid,celname,value,iRow,iCol){
UserData:
在某些情况下,我们接受到从服务器端传递过来的数据并不会自动的被jqGrid展现的,这个时候我们要么在接下来对它进行处理,要么在html代码里进行额外说明,这个时候userdata这个标签就用到了。
xmlReader: {userdata: "userdata",... }
In the data received from the server, this could be structured as follows (in xml): <invoices> <request>true</request>
希望这个帮助文档能对大家学习jQuery的插件jqGrid带来帮助(在个人的使用过程中不断更新),希望大家提出意见。
<userdata name="totalinvoice"> 240.00 </userdata> <userdata name="tax"> 40.00</userdata> ... <result>
<row>
<cell>data1</cell>
<cell>data2</cell>
<cell>data3</cell>
<cell>data4</cell>
<cell>data5</cell>
<cell>data6</cell>
</row> ... </result>
</invoices>
57页开始讲解增删查改
12.3 更新:
正在阅读:
强大的JQuery的插件jqGrid07-18
配套习题集 - 图文06-19
齐河一中高二第一周周周清数学试题06-28
2017北师大法硕毕业生找工作有什么优势05-15
2013年国家公务员考试热点时评01-31
班规班约和奖惩办法03-26
2016年物流师考试考场必备诀窍每日一讲(3月8日)01-05
工业风扇制造项目可行性研究报告05-19
- 教学能力大赛决赛获奖-教学实施报告-(完整图文版)
- 互联网+数据中心行业分析报告
- 2017上海杨浦区高三一模数学试题及答案
- 招商部差旅接待管理制度(4-25)
- 学生游玩安全注意事项
- 学生信息管理系统(文档模板供参考)
- 叉车门架有限元分析及系统设计
- 2014帮助残疾人志愿者服务情况记录
- 叶绿体中色素的提取和分离实验
- 中国食物成分表2020年最新权威完整改进版
- 推动国土资源领域生态文明建设
- 给水管道冲洗和消毒记录
- 计算机软件专业自我评价
- 高中数学必修1-5知识点归纳
- 2018-2022年中国第五代移动通信技术(5G)产业深度分析及发展前景研究报告发展趋势(目录)
- 生产车间巡查制度
- 2018版中国光热发电行业深度研究报告目录
- (通用)2019年中考数学总复习 第一章 第四节 数的开方与二次根式课件
- 2017_2018学年高中语文第二单元第4课说数课件粤教版
- 上市新药Lumateperone(卢美哌隆)合成检索总结报告
- 插件
- 强大
- JQuery
- jqGrid
- 二氧化碳的资源化利用
- 新目标版九年级英语上册教学案例新Microsoft Word 文档 (3)
- 儿童急性早幼粒细胞白血病研究进展
- 文言文练习题及答案
- 笔记揭露传销诀窍
- 五单元第一章动物的主要类群
- BS,CS的优缺点及适用场合
- 部编新教材使用经验及问题总结
- 东营市 八年级英语 语法填空训练八年级英语专项训练含答案解析
- 招商手册——品牌文化篇
- 五四红旗团支部申请书
- 九年级上__科学复习提纲__浙教版
- 绿色壁垒对我国农产品出口的影响及对策(1)
- 儿科护理学各章复习题
- 阳光体育主题班会
- 初中美术教学计划
- 城镇化调研工作报告
- 监控施工合同范本
- 医院消毒供应中心管理规范
- 闽发铝业:董事会审计委员会工作细则(2008年4月) 2011-08-04