保存或编辑后 JqGrid 不刷新记录



我使用 JqGrid 列出、添加、删除、编辑、查找我的记录。当我选择 loadonce=false 时,它通常会在 del、编辑或添加后刷新记录。但是,分页和搜索机制不起作用。一旦我选择了 loadonce=true,它会在删除后刷新记录,而不是在添加或编辑后刷新记录。然后分页和搜索在 loadonce=true 模式下正常运行。 我试过了;

$("#list").setGridParam({datatype:'json', page:1}).trigger('reloadGrid');

afterInsertRow: function (rowid,rowdata,rowelem){
    alert("hello"); // this wasnt invoked
}

但他们没有解决我的问题。

我的问题是什么原因。

如果您使用loadonce: false,则必须在服务器端实现分页,排序和搜索。如果分页和搜索不起作用,则表示您没有在当前服务器代码中实现这些功能。

该选项reloadAfterSubmit指定编辑后是否重新加载网格。

如果使用loadonce: truedatatype将在第一次加载后更改为'local'。问题是jqGrid不支持本地表单编辑。因此,您必须实现添加/编辑/删除的服务器部分。问题是在这种情况下重新加载将在本地执行,而不是从服务器执行。要在表单编辑结束后从服务器重新加载数据,您可以在回调中将datatype重置为初始状态("json"或"xml"afterSubmit)。在这种情况下,下一次重新加载(在reloadAfterSubmit: true的情况下)将像您想要的那样从服务器完成。

更新:以下 afterSubmit 代码应该可以解决问题:

afterSubmit: function () {
    $(this).jqGrid("setGridParam", {datatype: 'json'});
    return [true];
}

试试这段代码;

afterSubmit: function () { location.reload(true); }

最新更新