我正在使用jqGrid,并已将分组添加到我的某个网格中。当没有启用分组时,一切正常,但是一旦我添加:
grouping: true,
groupingView: { groupField: ['ProjName'], groupDataSorted: true }
我开始遇到一些奇怪的行为。当我单击其中一个列标题以更改排序顺序时,不会清除网格中的现有行,而是将新行追加到网格的末尾,并重置所有组。
换句话说,当页面首次绘制时,我看到了:
然后,我点击一个排序标题,我得到了这个:
我的初始化代码如下:
var gridMyTasks = $('#gridMyTasks').jqGrid({
jsonReader: { root: 'rows', repeatitems: false, id: 'ID' },
datatype: 'json',
colNames: ['Task ID', 'Task Name', 'Project Name', 'Task Stage', 'Doc Type', 'Due Date'],
colModel: [
{ name: 'ShortCode', width: 70, jsonmap: 'ShortCode' },
{ name: 'TaskName', width: 200, jsonmap: 'TaskName', formatter: 'fmtTaskName' },
{ name: 'ProjName', width: 200, jsonmap: 'ProjName', formatter: 'fmtName' },
{ name: 'TaskStage', width: 100, jsonmap: 'TaskStage' },
{ name: 'DocType', width: 130, jsonmap: 'DocType' },
{ name: 'DueDate', width: 70, jsonmap: 'DueDate' }
],
rowNum: 0,
height: 'auto',
autowidth: true,
forceFit: true,
multiselect: false,
caption: '',
altclass: 'zebra',
altRows: true,
hoverrows: false,
gridview: true,
grouping: true,
groupingView: { groupField: ['ProjName'], groupDataSorted: true }
});
我的加载程序代码(在sort上再次调用)如下所示:
loader(limit, curSort, curDir, function (results) {
grid[0].addJSONData({ rows: results });
$('body').hideLoading();
link.html(expanded ? 'Show less...' : 'Show all...');
},
null);
(loader
是对服务器的AJAX调用) - 我想也许我需要做些什么来清除所有现有的行?但是,为什么在启用分组之前它完全正常工作?
答案 0 :(得分:0)
我明白了。我有以下代码:
grid.setGridParam({
onSortCol: function (index, iCol, sortorder) {
wait();
curSort = index;
curDir = (sortorder == 'desc');
loadGrid(expanded ? null : 15);
return 'stop'; // <--- Problem
}
});
当我评论return 'stop'
时,问题就消失了。我不完全确定为什么我开始这样做,我想我试图禁用任何类型的内置排序。