我不相信gridComplete事件在“所有数据加载到网格中并且所有其他进程完成后”运行,如documentation中所指定的那样。
我有一个正确加载的网格。在gidComplete事件中,我正在触发一些过滤方法(.extend和.setGridParam),以便在加载网格后立即应用过滤器。但是,虽然我的自定义函数正在触发(通过控制台看到),但未应用过滤器。如果我使用setTimeout将执行延迟一秒(左右),则实际上应用了过滤器。因此在我看来,gridComplete过早发射。
顺便提一下,过滤器函数(称为setGridFilter())也会在绑定到选择菜单的onchange事件中触发(用户可以从中选择预设的过滤器选项)。这非常有效。这只是对此函数的gridComplete调用失败。
$("#list3").jqGrid({
url: 'blah.php',
colNames: ['blah1','blah2','etc.','PresentationTemplateID'],
colModel: [name: 'blah1', index: 'blah1'],
[name: 'blah2', index: 'blah2'],
[name: 'etc.', index: 'etc.'],
[name: 'PresentationTemplateID', index: 'PresentationTemplateID', hidden:true]
viewRecords:true,
loadonce: true,
pager: '#pager3',
search:true,
gridComplete: function(){
//var t = setTimeout('setGridFilter()',1000); //this works, for some reason
setGridFilter(); //this does not
}
});
function setGridFilter() {
var postdata = $("#list3").jqGrid('getGridParam','postData');
var text = $("#ddlGridFilterMenu").val(), f;
$.extend(postdata,{filters:'',searchField: 'PresentationTemplateID', searchOper: 'eq', searchString: text});
$("#list3").jqGrid('setGridParam', { search: text.length>0, postData: postdata });
$("#list3").trigger("reloadGrid",[{page:1}]);
}
答案 0 :(得分:0)
请尝试使用loadComplete
。