Строка общей суммы JQgrid - PullRequest
       1

Строка общей суммы JQgrid

5 голосов
/ 12 сентября 2011

я видел пример @Oleg для общей суммы строки в jqgrid, но я попытался применить ее, и она не работает, у меня есть следующая сетка, мне нужно вычислить значение суммы для нее.

colNames: ['ID', 'FTE', 'Workload'],
    colModel: [
                { name: 'ID', index: 'ID', width: 200, align: 'left', hidden: true },

                { name: 'FTEValue', index: 'FTEValue', width: 200, align: 'left', formatter: 'number' },
                { name: 'Workload', index: 'Workload', width: 200, align: 'left' },



    caption: "Activity FTE",
    gridview: true,
    rownumbers: true,
    rownumWidth: 40,
    scroll: 0,
    rowNum: 100,
    sortname: 'ID',
    pager: '#pager',
    sortorder: "asc",
    viewrecords: true,
    autowidth: true,
    height: '100%',
    footerrow: true,
    jsonReader: { root: "GridData", page: "CurrentPage", total: "TotalPages", records: "TotalRecords", repeatitems: false, id: "0" }
};



DutyFTEGrid.prototype.SetupGrid = function (selector) {
    jQuery(selector).html('<table id="grid"></table><div id="pager"></div>');
    var grid = jQuery("#grid").jqGrid(this.gridConfiguration);

    jQuery("#grid").jqGrid('navGrid', '#pager',
    { edit: false, add: false, search: false }, {}, {},
    { // Delete parameters
        ajaxDelOptions: { contentType: "application/json" },
        mtype: "DELETE",
        serializeDelData: function () {
            return ""; 
        },
        onclickSubmit: function (params, postdata) {
            params.url = serviceURL + 'DutyFTE(' + encodeURIComponent(postdata) + ')/';
        }
    });

    var grid = $("#grid");
    var sum = grid.jqGrid('getCol', 'FTE', false, 'sum');
    grid.jqGrid('footerData', 'set', { DriverEn: 'Total FTE:', FTEValue: sum });
};

Олег, пожалуйста, помогите, я попробовал ваш пример, но по какой-то причине он не сработал.

Ответы [ 2 ]

19 голосов
/ 13 сентября 2011

Если я правильно вас понял, вы хотите поместить в нижний колонтитул getCol и footerData методы:

var grid = $("#list"),
    sum = grid.jqGrid('getCol', 'amount', false, 'sum');

grid.jqGrid('footerData','set', {ID: 'Total:', amount: sum});

getCol может использоваться для вычисления суммы всех чисел из столбца «сумма», а в отношении footerData вы можете поместить внизу столбца 'ID' текст «Всего:» и в нижняя часть 'amount' столбца.

ОБНОВЛЕНО : Возможно, у вас есть проблемы, потому что вы поместили код в неправильном месте. Наиболее безопасным местом для кода является loadComplete обработчик событий. Посмотрите на демо .

0 голосов
/ 09 февраля 2012

Итого по столбцу цен:

//Count total for a price column
var total = 0;
$('#table tr').each(function(){

    //cells that contains the price
    var tdprice = $(this).find("td:eq(2)").html();

    //Sum it up!
    if (isNaN(tdprice)){ total += parseInt(tdprice); }
});

alert(total + "$");
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...