我的页面上有一个jqGrid,它使用json帖子接收到服务器的记录。在同一页面上,我还有一个删除按钮。单击删除按钮使用ajax发布到服务器以删除所选记录。删除记录后,如果服务器返回成功代码,我需要刷新网格。
除非网格中只有一条记录,否则它似乎工作正常。我删除的最后一条记录永远不会从网格中删除。即使我按下页脚上的刷新按钮,它仍然不会消失。当有多个记录时,它会像我期望的那样刷新。
我是jqGrid的新手,所以我确信我做错了。任何帮助将不胜感激。
jqGrid定义
$('#gridOrgs').jqGrid({
url: 'some url goes here',
datatype: 'json',
mtype: 'POST',
loadonce:false,
colNames: ['ID', 'Name', 'City', 'Province', 'Admin'],
colModel: [
{ name: 'Id', index: 'Id', hidedlg: true, hidden: true, sortable: false },
{ name: 'CompanyName', index: 'CompanyName', width: 200, sorttype: 'text' },
{ name: 'City', index: 'City', width: 150, sorttype: 'text' },
{ name: 'Province', index: 'Province', width: 150, sorttype: 'text' },
{ name: 'IsAdmin', index: 'IsAdmin', width: 50, sorttype: 'text', formatter: 'checkbox', align: 'center'},
],
pager: '#pagerOrgs',
jsonReader: {
repeatitems: false,
id: 'Id' },
rowNum: 10,
rowList: [10, 25, 50, 75, 100],
sortname: 'CompanyName',
sortorder: 'desc',
viewrecords: true,
caption: 'Companies',
hidegrid: false,
width: 650,
height: 400,
onSelectRow: function (id) {
if (id)
RowSelected(id, $('#gridOrgs').getCell(id,'IsAdmin'));
else
NoRowSelected();
}
});
jQuery("#gridOrgs").jqGrid('navGrid','#pagerOrgs',{edit:false,add:false,del:false});
删除按钮点击事件:
$('#btnDelete').click(function() {
var id = jQuery("#gridOrgs").jqGrid('getGridParam','selrow');
if (id)
$.post('@Url.Action("Json_Delete", "Organization")', {'id': id}, function(data){ProcessDeleteResponse(data.result);}, 'json');
else
$('#dialogNothingSelected').dialog('open');
});
function ProcessDeleteResponse(resultCode) {
if (resultCode == 'success')
$('#gridOrgs').trigger('reloadGrid');
}
我也试过
.trigger('reloadGrid',[{page:1}]);
.trigger('reloadGrid',[{current:true}]);
无论我做什么,最后一条记录都留在网格中。
最后一件事:当我触发reloadGrid时,网格会调用服务器并接收更新的信息。更新的信息包含0表示记录总数。
再次感谢。
答案 0 :(得分:0)
我似乎可以通过调用以下方法来解决此问题:
$('#gridOrgs').jqGrid('delRowData', id);
让我知道是否有人有更好的解决方案。