У меня есть требование фильтровать данные локально в jqgrid без использования встроенного пользовательского интерфейса. Я последовал ответу Олега в сообщении jqGrid Filtering Records. Это сработало как шарм с некоторыми изменениями в моей настройке. Однако я не могу заставить его работать для поля, в котором отформатированы записи. Данные jqgrid являются удаленными.
Размещение образца кода из jqGrid Filtering Records, поскольку это в значительной степени то, что у меня есть:
$("#search").click(function() {
var searchFiler = $("#filter").val(), grid = $("#list"), f;
if (searchFiler.length === 0) {
grid[0].p.search = false;
$.extend(grid[0].p.postData,{filters:""});
}
f = {groupOp:"OR",rules:[]};
f.rules.push({field:"name",op:"cn",data:searchFiler});
f.rules.push({field:"note",op:"cn",data:searchFiler});
grid[0].p.search = true;
$.extend(grid[0].p.postData,{filters:JSON.stringify(f)});
grid.trigger("reloadGrid",[{page:1,current:true}]);
});
В моем случае поле name отформатировано в jqgrid:
{name:"name", index:"name", width:250, align:'left',
formatter: function(cellvalue, options, rowObject)
{
return rowObject.Data[0]['userName'];
}
},
...
jsonReader : {
repeatitems:false,
root: 'rows',
userdata: 'rows'
},
loadonce: true,
viewrecords: true,
autowidth: true,
multiselect: false,
height: 500,
rowNum: 999,
subGrid: true,
Мы делаем запрос к бэкэнду один раз и сохраняем данные в «строках» для отображения в подсетке.
Любые указатели приветствуются.
Благодарность,
Аша