使用Trirand的jqGrid计算gridComplete事件

时间:2011-09-23 13:26:10

标签: javascript jquery jqgrid

我不相信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}]);
}

1 个答案:

答案 0 :(得分:0)

请尝试使用loadComplete