javascript - jqGrid 子网格的 JSON 对象

标签 javascript jquery datagrid jqgrid

这是我关于 jqGrid 的子网格的 JSON 数据的第 3 个问题,直到现在我还没有收到任何评论。请有人帮忙。

我的 1st question
2nd one

我无法了解 jqGrid 中子网格使用的 json 格式。在我的第二个问题中,我询问了我应该为特定场景使用的格式

对于给定的图像 enter image description here

这是正确的 JSON 字符串吗?

var myJSONObject = {
"list": [
    {
        "elementName": "TERM",
        "attribute": [
            {
                "name": "information",
                "firstValue": "Required fixes for AIX",
                "secondValue": "Required fixes for AIX"
            },
            {
                "name": "name",
                "firstValue": "PHCO_34",
                "secondValue": "PHCO_34"
            },
            {
                "name": "version",
                "firstValue": "1.0",
                "secondValue": "2.0"
            }
        ],
        "isEqual": false,
        "isPrasentinXml1": true,
        "isPrasentinXml2": false
    },
    {
        "elementName": "Asian-Core.ASX-JPN-MAN",
        "attribute": [
            {
                "name": "information",
                "firstValue": "Man",
                "secondValue": "Man"
            },
            {
                "name": "name",
                "firstValue": "Asian-Core.ASX-JPN-MAN",
                "secondValue": "Asian-Core.ASX-JPN-MAN"
            },
            {
                "name": "version",
                "firstValue": "B.11.23",
                "secondValue": "B.11.23"
            }
        ],
        "isEqual": false,
        "isPrasentinXml1": true,
        "isPrasentinXml2": true
    }
]
};

如果是,我的第一个问题这是我到目前为止达到的目标

$('#compareContent').empty();
    $('<div id="compareParentDiv" width="100%">')
    .html('<table id="list2" cellspacing="0" cellpadding="0"></table>'+
            '<div id="gridpager2"></div></div>')
    .appendTo('#compareContent');

    var grid = jQuery("#list2");

    grid.jqGrid({
        datastr : myJSONObject,
        datatype: 'jsonstring',

        colNames:['Name','Result1', 'Result2'],
        colModel:[
            {name:'elementName',index:'elementName', width:90},
            {name:'isPrasentinXml1',index:'isPrasentinXml1', width:100},
            {name:'isPrasentinXml2',index:'isPrasentinXml2', width:100},
        ],
        pager : '#gridpager2',
        rowNum:10,
        scrollOffset:0,
        height: 'auto',

        autowidth:true,
        viewrecords: true,
        gridview: true,
        jsonReader: { repeatitems : false, root:"list" },
        subGrid: true,

        /*subGridModel: [{
            //subgrid columns names
            name: ['Name', 'Version', 'Information'],
            //subgrid columns widths
            width: [200, 100, 100],
            //subrig columns aligns
            align: ['left', 'left', 'left']

          }]*/

        // define the icons in subgrid
        subGridOptions: {
            "plusicon"  : "ui-icon-triangle-1-e",
            "minusicon" : "ui-icon-triangle-1-s",
            "openicon"  : "ui-icon-arrowreturn-1-e",
            //expand all rows on load
            "expandOnLoad" : true
        },
        subGridRowExpanded: function(subgrid_id, row_id) {
            var subgrid_table_id, pager_id;
            subgrid_table_id = subgrid_id+"_t";
            pager_id = "p_"+subgrid_table_id;
            $("#"+subgrid_id).html("<table id='"+subgrid_table_id+"' class='scroll'></table><div id='"+pager_id+"' class='scroll'></div>");
            jQuery("#"+subgrid_table_id).jqGrid({
                datastr : myJSONObject,
                datatype: 'jsonstring',
                colNames: ['Name','Value1','Value2'],
                colModel: [
                    {name:"name",index:"name",width:90},
                    {name:"firstValue",index:"firstValue",width:100},
                    {name:"secondValue",index:"secondValue",width:100},
                ],
                rowNum:20,
                pager: pager_id,
                sortname: 'name',
                sortorder: "asc",
                height: 'auto',
                autowidth:true,
                jsonReader: { repeatitems : false, root:"attribute" }
            });
            jQuery("#"+subgrid_table_id).jqGrid('navGrid',"#"+pager_id,{edit:false,add:false,del:false})
        }
    });
    grid.jqGrid('navGrid','#gridpager2',{add:false,edit:false,del:false});

欢迎任何类型的建议/评论/解决方案。谢谢

我的输出

enter image description here

最佳答案

您的代码在 myJSONObject 的声明中有小错误变量和创建 div#compareContent 包含的代码应该固定为

$('#compareContent').empty();
$('<div id="compareParentDiv" width="100%">'+
  '<table id="list2" cellspacing="0" cellpadding="0"></table>'+
        '<div id="gridpager2"></div></div>')
.appendTo('#compareContent');

其他小的语法错误是 colModel 中的尾随逗号: 应删除“]”之前的逗号。

现在解决您的主要问题。你应该改变 datastr : myJSONObject在子网格中类似

datastr : myJSONObject.list[0]

然后修改后的演示将显示数据:参见here .

您遇到的另一个问题是数据中缺少 id。您应该修改数据的结构来为非常网格行和每个子网格行定义唯一的 id。您应该考虑到数据中的 ID 将用作 <tr> 的 ID。元素和 HTML 不允许在一个 HTML 页面上有重复的 id。

更新:参见here修改 JSON 输入和 jqGrid 以便使用 id 的示例。

关于javascript - jqGrid 子网格的 JSON 对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6649451/

相关文章:

javascript - 将回调功能添加到我的简单 javascript 函数

apache-flex - 在包含可变行高的 Spark 数据网格上设置正确的高度

wpf - 从数据网格中 Tab 到下一个控件

javascript - 谷歌地图导致本地403禁止

javascript - 当我刚刚访问数组时,为什么会出现 NaN ?

javascript - 请求一个基于 jquery 的轻量级图表库

javascript - 我想找到用 jquery 替换一个 url 查询参数

python - 不均匀(曲线)网格的 Matplotlib 流图

javascript - 使用相机拍照或使用 phonegap 从画廊弹出窗口中选择

来自 Javascript JSONArray 的 Java JSONArray