我正在使用 jqGrid,到目前为止一切都运行良好。但现在我正在努力允许用户能够保存他们的搜索,以便他们以后可以检索它们和/或将它们应用到不同的网格。事实证明,节省实际上是最容易的部分。我可以根据指定的 postData 过滤器获取网格进行过滤,但搜索对话框不会使用过滤条件刷新。这是我的一个小测试:
$("#grid").jqGrid('navGrid','#pager', {edit: false, add: false, del: false, refresh: false, searchtext: 'Search'}, {}, {}, {},
{
multipleSearch: true,
closeAfterSearch: true,
closeOnEscape: true,
searchOnEnter: true,
Find: "Search",
afterShowSearch: function ()
{
...// code to create the save search buttons goes here
$("#fbox_" + gridID + "_save").bind('click', function()
{
var filters = {"groupOp":"AND","rules":[{"field":"id","op":"eq","data":"2"}]};
$('#grid').jqGrid('setGridParam',
{
postData: {'filters': filters}, search: true}).trigger('reloadGrid');
}
}
});
我已经尝试了几种方法,但似乎没有任何方法可以更新高级搜索对话框。
作为旁注...我没有将重新创建过滤器设置为 true。似乎某处存在错误...重新创建过滤器设置为 true,当您应用搜索时,关闭对话框,重新打开搜索对话框,点击“重置”,关闭对话框,然后返回,没有可用选项。我得到的只是“分组”选项(和/或)。我在 Oleg 的一些演示中对此进行了测试,结果是相同的,所以这不仅仅是我的代码。
最佳答案
设置recreateFilter: true解决了显示问题。但是,它仍然存在问题,即单击“重置”按钮后,关闭搜索对话框,然后返回搜索对话框,您只能看到组运算符下拉列表(“AND/OR”)和旁边的“+”按钮。我能够通过触发“+”按钮上的点击事件来解决这个问题
var tableRows = $('#fbox_grid > table').find('tr');
if (tableRows.length == 2)
{
$('input[type="button"]').trigger('click');
}
现在一切都很好。
关于jqgrid - 如何使用 postData 过滤器刷新 jqGrid 搜索对话框,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16529277/