FooterRow摘要值在Jqgrid中过滤记录时不会更改

时间:2013-04-03 05:32:57

标签: asp.net jqgrid

我有一个函数,它将计算特定列的摘要并将其加载到网格的页脚中。这是代码..

$(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提前..

1 个答案:

答案 0 :(得分:0)

使用grid.jqGrid('getGridParam', 'data')计算页脚行的值(摘要行)。如果您需要从所有页面访问所有本地数据,而不依赖于使用的过滤器,这是实用的。如果您需要从当前显示的数据页面计算摘要(并且应用了过滤器),则应使用grid.jqGrid('getRowData')代替。