我试图使用jQGrid构建一个子网格来显示父子关系。我遵循了经理和员工的关系。 我正在服务器上构建一个JSON,这就是它的外观
{"total":1,"page":1,"records":20,
"rows":[{"id":"Mgr 001","EmpId":"Mgr 001","Manager Name":"Murali","Dept":"D1"
,"Employees":[{"EmpId":"Emp 100","Name":"Alex","Dept":"Infrastucture"}]}]
问题是,当我点击展开时,我正在查找数据 本地存储的employeeLocalJSON变量并分配集合 到子网格。但它没有在子网格中显示。我不知道为什么会这样 所以。我想从服务器加载json并显示我应该使用的子网格 同样,所以我将其存储在局部变量employeeLocalJSON中。
我关注jqgrid subgrids from a single nested json
jqGrid Subgrid with "local" Data
JqGrid with subgrid and single XML file as input
这是我的jQGrid代码
$(function() {
var employeeLocalJSON;
jQuery("#list").jqGrid({
//start
url: '/Employee/Search',
datatype: "json",
postData: {
searchModel: function () {
var result = {}, i, item,
formInfo = $('#search-form').serializeArray(),
l = formInfo.length;
for (i = 0; i < l; i++) {
item = formInfo[i];
result[item.name] = item.value;
}
return JSON.stringify(result);
}
},
mtype: "POST",
colNames: ['id', 'EmpId', 'Manager Name', 'Dept'],
colModel: [
{ name: 'id', index: 'id', hidden: true, width: 1, align: 'left', key: true },
{ name: 'EmpId', index: 'EmpId', search: true, width: 260, align: 'left' },
{ name: 'ManagerName', index: 'ManagerName', search: false, width: 110, align: 'left' },
{ name: 'Dept', index: 'Dept', search: true, width: 54, align: 'left' }],
pager: $("#pager"),
rowNum: 20,
rowList: [5, 10, 20, 50],
sortname: 'EmpId',
sortorder: "asc",
viewrecords: true,
loadonce: true,
sortable: true,
jsonReader: {
repeatitems: false
},
loadComplete: function (data) {
if (data.rows) {
employeeLocalJSON = data.rows; // save original JSON data
}
},
caption: 'Employee Manager Detail',
subGrid: true,
subGridOptions: {
"plusicon": "ui-icon-triangle-1-e",
"minusicon": "ui-icon-triangle-1-s",
"openicon": "ui-icon-arrowreturn-1-e",
"reloadOnExpand": false,
"selectOnExpand": true
},
subGridRowExpanded: function (grid_id, row_id) {
// //start of subgrid row expanded
var subgrid_table_id, pager_id;
subgrid_table_id = grid_id + "_tone";
pager_id = "pone_" + subgrid_table_id;
$("#" + grid_id).html("<table id='" + subgrid_table_id + "' class='scroll' style='width:100%'></table><div id='" + pager_id + "' class='scroll'></div>");
var indexes = $(this).jqGrid('getGridParam', '_index');
var empList = employeeLocalJSON[indexes[row_id]].Employees;
$("#" + subgrid_table_id).jqGrid({
datatype: 'local',
data: empList,
colNames: ['EmpId', 'Name', 'Dept'],
colModel: [
{ name: 'EmpId', width: 170 },
{ name: 'Name', width: 110 },
{ name: 'Dept', width: 60 }
],
sortname: 'EmpId',
viewrecords: true,
sortorder: "asc",
width: 960
});
}
//end
});
// });
jQuery("#list").jqGrid('navGrid', '#pager', { add: false, edit: false, del: false });
});
如何从单个JSON加载子网格?我的代码可能有什么问题?我无法看到子网格,即使我绑定了数据
答案 0 :(得分:2)
您遇到的第一个重要问题是在id
值中使用空格(请参阅数据中的"id":"Mgr 001"
)。我可以建议你两个解决问题的方法。第一个是更改算法如何生成id值。例如,如果可能,您可以从id中删除所有空格,或将" "
替换为任何其他字符。另一种方法是更改jqGrid代码的the line
return String(sid).replace(/[!"#$%&'()*+,.\/:;<=>?@\[\\\]\^`{|}~]/g,"\\$&");
到
return String(sid).replace(/[!"#$%&'()* +,.\/:;<=>?@\[\\\]\^`{|}~]/g,"\\$&");
(在应由jqGrid编码的字符列表中添加空格)。
要将一个响应中的子网格信息与主网格数据一起发布,我建议您使用userdata
部分JSON,稍后将以"userData"
进行访问(案例为重要!!!)jqGrid的参数。如果您无法在服务器端执行此操作,则可以在beforeProcessing
回调内对服务器响应进行相应的转换。有关相应的代码示例,请参阅the answer。
更新:我再次提醒Tony(见here)有关逃避id
空格的建议。刚才(见here)更改包含在jqGrid的主代码中。因此,在下一个版本中(当前4.4.3更高版本),jqGrid将使用具有空格的ID。