我有jqGrid,它最初是空的(我只在_search为true时从服务器返回数据)。 这是网格代码:
jQuery(gridId).jqGrid({
url : '/controller/GetData',
height : 100,
multiplesearch : true,
datatype : "json",
mtype : "POST",
rowNum : 10,
rowList : [ 10, 20, 30 ],
sortname : 'LBONumber',
sortorder : "desc",
viewrecords : true,
onSelectRow: jqGridRowSelected,
caption : 'DATA',
colNames : ["LBO","First name","Adress"],
colModel : [{"name":"LBONumber","index":"LBONumber","hidden":false},{"name":"FirstName","index":"FirstName","hidden":false},{"name":"Adress","index":"Adress","hidden":false},
});
我有id为“LBO”的文本字段,点击按钮我执行此代码:
$(gridId).setGridParam({
search: true,
postData: {
'filters':$.param({
'groupOp': 'AND',
'rules': [{ "field": 'LBONumber', "op": 'eq', "data": function () { return $("#LBO").val() } }]
})
}
});
我的问题是请求正文,即:
_search=true&nd=1306834594225&rows=10&page=1&sidx=LBONumber&sord=desc&filters%5BgroupOp%5D=AND&filters%5Brules%5D%5B0%5D%5Bfield%5D=LBONumber&filters%5Brules%5D%5B0%5D%5Bop%5D=eq&filters%5Brules%5D%5B0%5D%5Bdata%5D=333
它应该说...filters=...
,而不是...filters%5B...
,我不想在服务器上处理它,它必须是使这项工作正确的方法。我知道这实际上是正确的序列化对象,但我需要这个函数以与jqGrid包含的搜索相同的方式工作,因为我已经为这种情况完成了服务器端代码。
答案 0 :(得分:3)
以错误的方式构建filters
。而不是使用$.param,filters
的值必须是JSON.stringify
的JSON编码(请参阅the documentation)。 The answer包含相应的代码示例。
更新:postData
的定义可以是以下内容
postData: {
filters: function () {
return JSON.stringify(
{ groupOp: "AND", rules: [
{ field: 'LBONumber', op: 'eq', data: $("#LBO").val() }
]}
);
})
}