我有一个函数,它将计算特定列的摘要并将其加载到网格的页脚中。这是代码..
$(function () {
var gridData = null;
var nn = null;
grid = $("#gridId"),
calculateTotal = function () {
var gridData = grid.jqGrid('getGridParam', 'data'),
i = 0, totalAmount = 0, totalduration = 0;
for (; i < gridData.length; i++) {
var rowData = gridData[i];
totalAmount += Number(rowData.price);
totalduration += Number(rowData.duration);
}
grid.jqGrid('footerData', 'set', { name: "TOTAL", duration: totalduration, price: totalAmount });
};
});
现在我在这里调用这个摘要函数......
$.ajax({
url: 'Default.aspx/MyMethod',
dataType: 'json',
contentType: "application/json; charset=utf-8",
type: 'POST',
success: function (ReportDataNew, textStatus, XMLHttpRequest) {
//debugger;
gridData = JSON.parse(ReportDataNew.d);
console.log(gridData);
//alert(gridData.length);
$("#gridId").jqGrid({
data: gridData,
datatype: "local",
height: '100%',
autowidth: true,
ignoreCase: true,
rowNum: 50,
rowList: [50, 100, 200],
colNames: ['UserName', 'Duration', 'Destination', 'Price'],
colModel: [
{ name: 'username', index: 'username', width: 100, sortable: true, align: 'center' },
{ name: 'duration', index: 'duration', width: 100, sortable: true, align: 'center' },
{ name: 'destination', index: 'destination', width: 100, sortable: true, align: 'center' },
{ name: 'price', index: 'price', width: 100, sortable: true, align: 'center', formatter: 'currency' }
],
pager: '#gridpager',
viewrecords: true,
toppager: true,
loadtext: 'Loading...',
footerrow: true,
userDataOnFooter: true,
loadComplete: function () {
calculateTotal();
}
});
但是,从过滤器工具栏过滤记录时,页脚行的摘要值仍然相同... 我需要在过滤器工具栏上过滤或在搜索后在页脚上更新摘要值...
任何帮助将非常感谢/。 Thnx提前..
答案 0 :(得分:0)
使用grid.jqGrid('getGridParam', 'data')
计算页脚行的值(摘要行)。如果您需要从所有页面访问所有本地数据,而不依赖于使用的过滤器,这是实用的。如果您需要从当前显示的数据页面计算摘要(并且应用了过滤器),则应使用grid.jqGrid('getRowData')
代替。