我有一个加载良好的Struts2 jqGrid页面。单击导航器刷新按钮时,我希望它从服务器重新加载网格。
<sjg:grid
altRows="false"
id="gridtable"
dataType="json"
editurl="%{editurl}"
filter="true"
filterOptions="{stringResult:true}"
gridModel="gridModel"
gridview="true"
height="600"
href="%{remoteurl}"
loadonce="true"
navigator="true"
navigatorAdd="%{editPermission}"
navigatorAddOptions="{
closeAfterAdd:false,
closeOnEscape:true,
reloadAfterSubmit:true,
addCaption:'Add Record'}"
navigatorDelete="false"
navigatorEdit="%{editPermission}"
navigatorEditOptions="{
closeAfterEdit:false,
closeOnEscape:true,
afterSubmit:function(response, postdata) {
return isError(response.responseText);
}
}"
navigatorRefresh="true"
navigatorSearch="false"
onCompleteTopics="loadComplete"
onSelectRowTopics="rowselect"
onEditInlineBeforeTopics="beforeFormLoad"
pager="true"
pagerButtons="true"
rowList="25,50,100"
rowNum="25"
rownumbers="true"
>
我有以下绑定,以便在单击刷新按钮时将数据类型设置为 json。
$("#refresh_gridtable").bind("click", function(){
$("#gridtable").jqGrid("setGridParam", {datatype: 'json'});
return [true];
});
但是,当我单击刷新按钮时,它仅在每隔单击一次时从服务器重新加载数据。如果我对特定列执行客户端排序,然后单击刷新,则第一次单击时不会从服务器重新加载,第二次单击将从服务器刷新而不进行排序(排序图标在列顶部的这一点上仍然可见),然后第三次单击不会命中服务器,但会应用排序。
如何让刷新每次都从服务器重新加载,然后应用任何现有的排序/过滤器字段?
取决于你使用的底层 jqGrid。如果您使用免费的jqGrid 4.9,那么您可以使用navGrid
:reloadGridOptions: { fromServer: true }
的附加选项。
如果您使用旧版本的 jqGrid,则可以使用回调beforeRefresh
在重新加载之前直接将datatype
重置为 "json"
。我自己不使用 Struts2。所以我不知道在哪里可以指定回调beforeRefresh
或者,您可以使用navigatorRefresh="false"
从导航器栏中删除标准的"刷新"按钮,并使用似乎可以替代 navButtonAdd 的navigatorExtraButtons
。如果我正确理解该选项,您可以指定 onclick
的免费代码,它可以满足您的所有需求。您可以使用icon: "ui-icon-refresh"
使自定义按钮看起来与标准刷新按钮完全相同。在onclick
内部,您可以设置datatype: 'json'
并触发"reloadGrid"
。