时间:2021-05-26
jqGrid提供了表格底部汇总、合计行功能,我们先看下user-guide关于jqGrid合计行都有哪些说明?然后再看个DEMO,看看jqGrid表格底部汇总、合计行到底如何实现。
1、user-guide关于jqGrid合计行的说明
1)表格配置:footerrow, boolean, 默认false
If set to true this will place a footer table with one row below the gird records and above the pager. The number of columns equal those specified in colModel
表格是否显示底部合计行。
2)表格配置:userDataOnFooter,boolean,默认false
When set to true we directly place the user data array userData in the footer if the footerrow parameter is set to true. The rules are as follows: If the userData array contains a name which matches any name defined in colModel, then the value is placed in that column. If there are no such values nothing is placed. Note that if this option is used we use the current formatter options (if available) for that column. See footerData method.
如果设为true,则userData可以用来填充汇总行。
3)汇总行赋值:footerData([string action], [object data], [boolean format])
This method gets or sets data on the grid footer row. When set data in the footer row, the data is formatted according to the formatter (if defined) in coModel. The method can be used if footerrow option is set to true.
parameters
string action - can be ‘get' or ‘set'. The default is get. ‘get' returns an object of type name:value, where the name is a name from colModel. This will return data from the footer. The other two options have no effect in this case. ‘set' takes a data object and places the values in the footer The value is formatted according to the definition of the formatter in colModel - see next parameter. The object should be in name:value pair, where the name is the name from colModel
object data - data to be set in the footer in name:value pair, where the name should correspond to the name of colModel in order to be set in the appropriate cell.
boolean format - default is true. This instruct the method to use the formatter (if set in colModel) when new values are set. A value of false will disable the using of formatter
2、一个DEMO,如何利用gridComplete事件进行表格数据汇总并赋值给合计行
1)案例截图
2)html代码
<!DOCTYPE html><html><head> <meta charset="UTF-8" /> <title>jggrid底部汇总行</title> <link rel="stylesheet" href="https://cdn.bootcss.com/twitter-bootstrap/3.3.7/css/bootstrap.min.css" rel="external nofollow" /> <link rel="stylesheet" href="https://cdn.bootcss.com/font-awesome/4.5.0/css/font-awesome.min.css" rel="external nofollow" /> <link rel="stylesheet" href="https://cdn.bootcss.com/jqueryui/1.11.0/jquery-ui.min.css" rel="external nofollow" /> <link rel="stylesheet" href="https://js.cybozu.cn/jqgrid/v5.3.1/css/ui.jqgrid.css" rel="external nofollow" /> <script src="https://cdn.bootcss.com/jquery/1.11.1/jquery.min.js"></script> <script src="https://js.cybozu.cn/jqgrid/v5.3.1/js/jquery.jqGrid.min.js"></script> <script src="https://js.cybozu.cn/jqgrid/v5.3.1/js/i18n/grid.locale-en.js"></script></head><body><div class="page-content container"> <div class="page-body"> <!-- page-body --> <div class="panel panel-default" id="panel-orders"> <table id="orders"></table> </div> </div></div><script type="text/javascript"> var data = []; function getBills() { var rowCount = 10; for (var i = 0; i < rowCount; i ++) { data.push({ sid: i, goods_no: i + 1, goods_name: '零件名称' + rowCount + i, car_type_name: '车型' + rowCount + i, package_name: '包装器具' + rowCount + i, unit_name: '件', snp: 0.89, bill_amount: rowCount + i, goods_count: rowCount + i, bill_no: 'BN0000000' + i, qrcode: '1000000000' + i, barcode: '1000000000' + i, }) } $("#orders").jqGrid("clearGridData").jqGrid('setGridParam',{data: data || []}).trigger('reloadGrid'); } $(function() { $("#orders").jqGrid({ colModel: [ {label: "零件号", name: "goods_no", width: 60}, {label: "零件名称", name: "goods_name", search:false, width: 180}, {label: "车型", name: "car_type_name", width: 70}, {label: "包装器具", name: "package_name", width: 70}, {label: "单位", name: "unit_name", width: 40}, {label: "订单号", name: "bill_no", width: 120}, {label: "订单数量", name: "goods_count", width: 80}, ], datatype: 'local', rownumbers: true, height: 300, rowNum: 1000, footerrow: true, gridComplete: function() { var rows = $("#orders").jqGrid("getRowData"), total_count = 0; for(var i = 0, l = rows.length; i<l; i++) { total_count += (rows[i].goods_count - 0); } $("#orders").jqGrid("footerData", "set", {goods_name:"--合计--",goods_count:total_count}); } }); getBills(); });</script></body></html>3)代码说明:
gridComplete fires after all the data is loaded into the grid and all other processes are complete. Also the event fires independent from the datatype parameter and after sorting paging and etc. Does not fire if datatype is a defined as function.
4)获取汇总行数据
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
表格的第一二行一般是表格的名称和表格列信息,比如下图中的第一行为表名“职工档案汇总表”表格的第二行为各列的名称,比如本表为&ldqu
表格的第一二行一般是表格的名称和表格列信息,比如下图中的第一行为表名“职工档案汇总表”表格的第二行为各列的名称,比如本表为“
表格的第一二行一般是表格的名称和表格列信息,比如下图中的第一行为表名“职工档案汇总表”表格的第二行为各列的名称,比如本表为&ldqu
首先对Jqgrid网格插件做个简要的说明。在众多的表格插件中,Jqgrid的特点是非常鲜明的。特点如下:完整的表格呈现与运算功能,包含换页、栏位排序、group
jqGrid是一款基于jQuery的功能强大的表格插件,使用jqGrid可以轻松实现前端页面与后台数据进行ajax异步通信,jqGrid运行速度相当快,可以很好