1

我有最初为空的 jqGrid(仅当 _search 为真时,我才从服务器返回数据)。这是网格代码:

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 包含的搜索相同的方式工作,因为我已经为这种情况完成了服务器端代码。

4

1 回答 1

3

filters以错误的方式构建。而不是使用$.param的值filters必须是 JSON 编码(参见文档),JSON.stringify例如。答案包含相应的代码示例。

更新:的定义postData可以是以下

postData: {
    filters: function () {
        return JSON.stringify(
            { groupOp: "AND", rules: [
                { field: 'LBONumber', op: 'eq', data: $("#LBO").val() }
            ]}
        );
    })
}
于 2011-05-31T12:21:27.857 回答