我不想使用ajax在我的网格中加载数据。有没有一种方法可以静态地将所有数据加载到主网格和子网格?
在jqGrid文档中的示例中,需要参数subGridUrl
。但我想要一些类似的东西:
var mydata = [ {
// ... some static code for data creation here
} ]
并在参数data
中使用mydata,但subGrid没有此参数或其他内容。
如果使用子网格作为网格,则必须在subGridRowExpanded
回调中创建新网格。回调获取rowid
作为参数。因此,如果你想得到一个数据数组,它可以用作子网格的data
参数,那么子网格可以用datatype: 'local'
来定义。
代码模式可以是以下内容:
var mainGridData = [
{id: 'm1', ...},
{id: 'm2', ...},
],
subgridData1 = [
{id: 's11', ...},
{id: 's12', ...},
],
subgridData2 = [
{id: 's21', ...},
{id: 's22', ...},
],
subgridByMainGridId = {
m1: subgridData1,
m2: subgridData2
};
$('#mainGrid').jqGrid({
datatype: 'local',
data: mainGridData,
....
subGrid: true,
subGridRowExpanded: function(subgridId, rowId) {
var subgridTableId = subgridId + "_t";
$("#" + $.jgrid.jqID(subgridId)).html('<table id="' +
subgridTableId + '"></table>');
$("#" + $.jgrid.jqID(subgridTableId)).jqGrid({
datatype: 'local',
data: subgridByMainGridId[rowId],
...
});
});