我一直试图让“网格作为子网格”功能正常工作,但运气不佳。我认为我在代码中做错了什么,因为它在独立测试中运行良好。然而,我终于注意到我的应用程序和我的测试页面之间的唯一区别是我的应用程序在 IE7 上运行,而我在 Firefox 中运行我的测试页面。果然,当我在 IE7 中加载测试页面时,我遇到了同样的问题。
将在 IE7 上重现该问题的代码如下:
$(function () {
function loadTasks(subgrid_id, row_id)
{
var id = subgrid_id + '_t';
$('#' + subgrid_id).html('<table id="' + id + '"></table>');
jQuery("#" + id).jqGrid({
datatype: 'local',
colNames: ['No','Item','Qty','Unit'],
colModel: [
{name:'num',index:'num',width:80,key:true},
{name:'item',index:'item',width:130},
{name:'qty',index:'qty',width:70,align:'right'},
{name:'unit',index:'unit',width:70,align:'right'}
],
height: '100%'
});
}
var x = $("#grid").jqGrid({
jsonReader: { root: "rows", repeatitems: false },
datatype: "json",
height: 'auto',
autowidth: true,
forceFit: true,
colNames:['ID','Name'],
colModel:[
{name:'id', key:true, index:'id', width:60, sorttype:"int", jsonmap:"id"},
{name:'name', index:'foobar', width:90, jsonmap: "name"}
],
subGrid: true,
subGridRowExpanded: loadTasks,
caption: "Results"
});
var jsonData = [
{id: 1, name: 'Apple'},
{id: 2, name: 'Banana'},
{id: 3, name: 'Pear'},
{id: 4, name: 'Orange'}
];
x[0].addJSONData( { rows: jsonData } );
});
它似乎在每一行上创建了一些虚假元素,这些元素在行内无法正确呈现。这是它在 IE7 上如何呈现的屏幕截图:
奇怪的是那些“未定义”行实际上是有效网格行的一部分,如果我将鼠标悬停在“Apple”上,那么第一个未定义行也会突出显示。
我选择 jqGrid 而不是其他网格的主要原因是它支持嵌套多个网格(我们的应用程序确实需要),但是我们的公司标准仍然是 IE7,所以我们需要支持这个浏览器。我能做些什么来让这个功能在 IE7 下正常工作吗?