jqGrid表格底部汇总、合计行footerrow处理


Posted in Javascript onAugust 21, 2019

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)案例截图

jqGrid表格底部汇总、合计行footerrow处理

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)代码说明:

  • 表格构建时,设置:footerrow: true
  • gridComplete(jqGridGridComplete)事件处理,进行数据汇总并赋值给合计行

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)获取汇总行数据

var row = $("#orders").jqGrid(“footerData”, “get”);

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript FormatNumber函数实现方法
Dec 30 Javascript
Javascript中的var_dump函数实现代码
Sep 07 Javascript
实用的Jquery选项卡TAB示例代码
Aug 28 Javascript
JavaScript对内存分配及管理机制详细解析
Nov 11 Javascript
jQuery中document与window以及load与ready 区别详解
Dec 29 Javascript
jquery利用json实现页面之间传值的实例解析
Dec 12 Javascript
jQuery正则验证注册页面经典实例
Jun 10 jQuery
JS 60秒后重新发送验证码的实例讲解
Jul 26 Javascript
JavaScript的setter与getter方法
Nov 29 Javascript
react-native封装插件swiper的使用方法
Mar 20 Javascript
javascript实现前端分页功能
Nov 26 Javascript
JavaScript中clientWidth,offsetWidth,scrollWidth的区别
Jan 25 Javascript
Vue仿微信app页面跳转动画效果
Aug 21 #Javascript
Angular 中使用 FineReport不显示报表直接打印预览
Aug 21 #Javascript
深入理解Vue keep-alive及实践总结
Aug 21 #Javascript
vue element 生成无线级左侧菜单的实现代码
Aug 21 #Javascript
微信小程序仿今日头条导航栏滚动解析
Aug 20 #Javascript
Vue中axios的封装(报错、鉴权、跳转、拦截、提示)
Aug 20 #Javascript
Vue formData实现图片上传
Aug 20 #Javascript
You might like
浅析ThinkPHP的模板输出功能
2014/07/01 PHP
php实现微信分享朋友链接功能
2019/02/18 PHP
tp5框架内使用tp3.2分页的方法分析
2019/05/05 PHP
使用laravel的migrate创建数据表的方法
2019/09/30 PHP
jQuery+ajax实现顶一下,踩一下效果
2010/07/17 Javascript
jquery实现table鼠标经过变色代码
2013/09/25 Javascript
jQuery通过扩展实现抖动效果的方法
2015/03/11 Javascript
JavaScript 常见安全漏洞和自动化检测技术
2015/08/21 Javascript
Angular多选、全选、批量选择操作实例代码
2017/03/10 Javascript
JavaScript数组和对象的复制
2017/03/21 Javascript
微信小程序通过保存图片分享到朋友圈功能
2018/05/24 Javascript
jQuery实现的五星点评功能【案例】
2019/02/18 jQuery
解决layer.open弹出框不能获取input框的值为空的问题
2019/09/10 Javascript
jquery实现垂直手风琴菜单
2020/03/04 jQuery
Python正则抓取新闻标题和链接的方法示例
2017/04/24 Python
python3+PyQt5+Qt Designer实现堆叠窗口部件
2018/04/20 Python
python 搜索大文件的实例代码
2019/07/08 Python
twilio python自动拨打电话,播放自定义mp3音频的方法
2019/08/08 Python
Python对Tornado请求与响应的数据处理
2020/02/12 Python
解决python-docx打包之后找不到default.docx的问题
2020/02/13 Python
PyTorch中Tensor的数据统计示例
2020/02/17 Python
Python paramiko 模块浅谈与SSH主要功能模拟解析
2020/02/29 Python
Django实现celery定时任务过程解析
2020/04/21 Python
Python调用JavaScript代码的方法
2020/10/27 Python
python中翻译功能translate模块实现方法
2020/12/17 Python
Omio美国:全欧洲低价大巴、火车和航班搜索和比价
2017/11/08 全球购物
Myprotein意大利官网:欧洲第一运动营养品牌
2018/11/22 全球购物
简单说说tomcat的配置
2013/05/28 面试题
初三物理教学反思
2014/01/21 职场文书
管理失职检讨书
2014/02/12 职场文书
大学生实习鉴定评语
2014/04/25 职场文书
安全生产演讲稿
2014/05/09 职场文书
个人四风问题对照检查材料
2014/10/01 职场文书
计算机专业自荐信
2015/03/05 职场文书
jQuery ajax - getScript() 方法和getJSON方法
2021/05/14 jQuery
Apache Pulsar结合Hudi构建Lakehouse方案分析
2022/03/31 Servers