我想您尝试在创建网格之前addJSONData
调用方法jQuery("#projectList").jqGrid({...});
addJSONData
几乎总是不需要使用(请参阅我关于该主题的第一篇文章中的一个)。同样,你永远不应该使用eval
邪恶的方法。一种使用jQuery.parseJSON或JSON.parse代替。
我想你应该用它datatype: 'json'
来解决你的问题。您应该发布更多代码来向您展示如何在您的情况下使用其他 jqGrid 选项。
更新:从您之前的问题来看,您似乎只想在单击“搜索”按钮时从表单中向服务器发送其他数据。在这种情况下,我建议将代码修改为以下
var $grid = $("#projectList");
$grid.jqGrid({
url: 'user595234.json',
datatype: "json",
serializeGridData: function (data) {
return $.param(data) + '&' + $("#project_search_form").serialize();
},
jsonReader: {id: "projectId", repeatitems: false},
colNames: ['ID', 'Name'],
colModel: [
{name: 'projectId', width: 255},
{name: 'name', width: 255}
],
rowNum: 10,
rowList: [10,20,30],
pager: '#projectPager',
sortname: 'projectId',
viewrecords: true,
sortorder: "desc",
caption: "Simple data manipulation",
height: "auto"
}).jqGrid("navGrid", "#projectPager", {edit: false, add: false, del: false});
$("#search").click(function () {
$grid.trigger("reloadGrid", [{page: 1}]);
});
在演示中,我只从使用jQuery.serialize的示例中获取了表单并对其进行了一些修改。它显示您需要的数据
此外,就像您可以轻松验证 Fiddler 或 Firebug 一样,URL 将附加如下附加参数
...?_search=false&nd=1336057299806&rows=10&page=1&sidx=projectId&sord=desc&a=1&b=2&c=3&d=4&e=7&f=8
标准参数
_search=false&nd=1336057299806&rows=10&page=1&sidx=projectId&sord=desc
将附加表单中的参数
a=1&b=2&c=3&d=4&e=7&f=8
在某些情况下,可以选择使用jQuery.serializeArray。它允许以另一种格式(如 JSON)序列化数据或将数据转换为另一种格式(参见此处),这些格式可以使用$.extend轻松与标准 jqGrid 参数合并。