当我在jqGrid中设置postData时,它在重新加载时没有正确序列化

时间:2011-05-31 11:49:38

标签: jqgrid http-post jqgrid-asp.net

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

1 个答案:

答案 0 :(得分:3)

以错误的方式构建filters。而不是使用$.paramfilters的值必须是JSON.stringify的JSON编码(请参阅the documentation)。 The answer包含相应的代码示例。

更新postData的定义可以是以下内容

postData: {
    filters: function () {
        return JSON.stringify(
            { groupOp: "AND", rules: [
                { field: 'LBONumber', op: 'eq', data: $("#LBO").val() }
            ]}
        );
    })
}