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 相关文章推荐
ExtJS Grid使用SimpleStore、多选框的方法
Nov 20 Javascript
使用jQuery避免鼠标双击的解决方案
Aug 21 Javascript
js select option对象小结
Dec 20 Javascript
jQuery新的事件绑定机制on()示例应用
Jul 18 Javascript
JavaScript动态改变表格单元格内容的方法
Mar 30 Javascript
Bootstrap教程JS插件滚动监听学习笔记分享
May 18 Javascript
js事件委托和事件代理案例分享
Jul 25 Javascript
Vue + better-scroll 实现移动端字母索引导航功能
May 07 Javascript
javascript实现考勤日历功能
Nov 29 Javascript
基于Express框架使用POST传递Form数据
Aug 10 Javascript
jquery实现掷骰子小游戏
Oct 24 jQuery
详解jQuery中的prop()使用方法
Jan 05 jQuery
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
PHP翻页跳转功能实现方法
2020/11/30 PHP
PHP实现字符串翻转功能的方法【递归与循环算法】
2017/11/03 PHP
php和C#的yield迭代器实现方法对比分析
2019/07/17 PHP
PHP实现Markdown文章上传到七牛图床的实例内容
2020/02/11 PHP
得到form下的所有的input的js代码
2013/11/07 Javascript
Jquery之Bind方法参数传递与接收的三种方法
2014/06/24 Javascript
jQuery移除tr无效的解决方法(tr是动态添加)
2014/09/22 Javascript
吐槽一下我所了解的Node.js
2014/10/08 Javascript
javascript实现全角转半角的方法
2016/01/23 Javascript
JQuery 的跨域方法推荐_可跨任何网站
2016/05/18 Javascript
jquery中用jsonp实现搜索框功能
2016/10/18 Javascript
jQuery图片加载显示loading效果
2016/11/04 Javascript
详解js的事件代理(委托)
2016/12/22 Javascript
nodeJS微信分享
2017/12/20 NodeJs
vue项目前端埋点的实现
2019/03/06 Javascript
使用 vue 实例更好的监听事件及vue实例的方法
2019/04/22 Javascript
Vue开发中遇到的跨域问题及解决方法
2020/02/11 Javascript
vue打包npm run build时候界面报错的解决
2020/08/13 Javascript
webstorm建立vue-cli脚手架的傻瓜式教程
2020/09/22 Javascript
Python基于Matplotlib库简单绘制折线图的方法示例
2017/08/14 Python
Python之csv文件从MySQL数据库导入导出的方法
2018/06/21 Python
python3实现名片管理系统
2020/11/29 Python
Python实现判断一个整数是否为回文数算法示例
2019/03/02 Python
Python 中包/模块的 `import` 操作代码
2019/04/22 Python
django框架中间件原理与用法详解
2019/12/10 Python
Python发送邮件封装实现过程详解
2020/05/09 Python
几款好用的python工具库(小结)
2020/10/20 Python
HTML5 贪吃蛇游戏实现思路及源代码
2013/09/03 HTML / CSS
定义一结构体数组表示分数,并求两个分数相加之和
2013/06/11 面试题
杭州联环马网络笔试题面试题
2013/08/04 面试题
在Ajax应用中信息是如何在浏览器和服务器之间传递的
2016/05/31 面试题
2014财务人员自我评价范文
2014/09/21 职场文书
清洁工个人工作总结
2015/03/05 职场文书
采购部年度工作总结
2015/08/13 职场文书
Mybatis-plus在项目中的简单应用
2021/07/01 Java/Android
十大最强奥特曼武器:怪兽战斗仪在榜,第五奥特之父只使用过一次
2022/03/18 日漫