排序jqGrid时,在自定义格式列中保持复选框的状态

时间:2012-06-19 13:50:43

标签: jqgrid

我有一个jqgrid加载,它使用自定义格式化程序显示bool值的复选框,当单击保存按钮时,这些值会持久存储 。但是,只要单击某个排序,就不会保留所有复选框的选中状态。

jQuery("#list2").jqGrid({
    url:myurl,
    datatype: "json",
    loadonce: true,
    colNames:['Inv No','Date', 'Client', 'Amount','Tax','Total','Notes'],
    colModel:[
        {name:'id',index:'id', width:55},
        {name:'isChecked',index:'isChecked', width:90, formatter:chkFmatter},
        {name:'name',index:'name asc, invdate', width:100},
        {name:'amount',index:'amount', width:80, align:"right"},
        {name:'tax',index:'tax', width:80, align:"right"},      
        {name:'total',index:'total', width:80,align:"right"},       
        {name:'note',index:'note', width:150, sortable:false}       
    ],
    rowNum:10,
    rowList:[10,20,30],
    pager: '#pager2',
    sortname: 'id',
    viewrecords: true,
    sortorder: "desc",
    caption:"JSON Example"
});
jQuery("#list2").jqGrid('navGrid','#pager2',{edit:false,add:false,del:false});

function chkFmatter(cellvalue, options, rowObject) {
    // do something here to format column
    return new_format_value
}

无论如何,我可以保留在排序,分页等时点击的复选框吗?

1 个答案:

答案 0 :(得分:2)

这是因为绑定到网格的数据没有被更新,因此任何新请求(分页,排序等)都将反映属性绑定的原始状态。您最好的选择是随时更改复选框的状态以更新实际数据以反映此情况。

您可以使用getGridParam检索绑定到网格的数据:

var data = $('#' + gridid).jqGrid('getGridParam', 'data');

然后要更新它,请使用rowid,列名和值来更新数据对象:

data[row - 1][columnname] = value;