0

我正在使用 JSP 和 Servlet(IDE:Eclipse,数据库:Oracle10)开发一个 Web 应用程序。我正在使用 jqGrid 以表格格式显示记录。

我想jqGrid从 servlet 中获取组合框的值,到目前为止我已经完成了以下操作。

我正在访问 JSP 脚本中的 Servlet 传递的数组。

<%
    String[] stageIDs = (String[])request.getAttribute("combo");
%>

以下是我的 colModel:

jQuery("#list10_d").jqGrid({
            height: "100%",
            url:'ProtocolJGridServChild?q=2&action=protAction',
            datatype: "xml",
colNames:['Sr. No.','PID',  'SID'],
colModel:[{name:'srNo',index:'srNo', width:35,sortable:true},
{name:'PID',index:'PID', width:100,sortable:false,editable:true,hidden:true},
{name:'SID',index:'SID', width:100, sortable:false, editable:true, edittype:"select",editoptions:{value:<%for(int i=0;i<stageIDs.length;i++)%><%="ID:"+ stageIDs[i]+";"%>}}
],
            rowNum:2,
            rowList:[2,4,6],
            pager: '#pager10_d',
            sortname: 'PID',
            viewrecords: true,
            sortorder: "asc",
            multiselect: true,
            editurl: "MyServletName",
            caption:"CRM_PROT_ACTIONS",
}).navGrid('#pager10_d',{edit:true,add:true,del:true});

for loop line但是我在将编辑选项分配给组合框时遇到了一个例外。请让我知道代码中是否有任何错误。

我的另一个问题是,有没有更好的方法从 servlet 为 jqGrid 中的组合框分配值(不使用 scriplet)?

4

2 回答 2

1

您应该使用dataUrl而不是valueeditoptions内部从服务器获取组合框的值。如果服务器返回 JSON 数据而不是 HTML 片段,您可以使用buildSelect将服务器响应从转换dataUrl为 jqGrid 需要的格式。确切的实现可能取决于您使用的 jqGrid 版本。您可以使用将ajaxSelectOptions相应的 Ajax 请求从默认的“html”更改为(请参阅此处)。请参阅此处的实施示例。typedataType"json"buildSelect

于 2013-01-17T09:46:25.040 回答
0

使用动态数据将组合框添加到 jqgrid ..

我已经使用以下方式完成了它。

jQuery("#list10_d").jqGrid({
        height: "100%",
        url:'ProtocolJGridServChild?q=2&action=protAction',
        datatype: "xml",
colNames:['Sr. No.','PID',  'SID'],
colModel:[{name:'srNo',index:'srNo', width:35,sortable:true},
{name:'PID',index:'PID', width:100,sortable:false,editable:true,hidden:true},
{name:'SID',index:'SID', width:100,sortable:false,editable:true,edittype:"select",editoptions: {dataUrl: 'MyServletURL?action=comboSID'}},
],
        rowNum:2,
        rowList:[2,4,6],
        pager: '#pager10_d',
        sortname: 'PID',
        viewrecords: true,
        sortorder: "asc",
        multiselect: true,
        editurl: "MyServletName",
        caption:"CRM_PROT_ACTIONS",
}).navGrid('#pager10_d',{edit:true,add:true,del:true});

小服务程序

if(request.getParameter("action").equalsIgnoreCase("comboSID"))
{
        String s[][] = select.getData("select SID from TABLE_NAME_HERE where PID='"+ param +"'"); //returns 2D array
        StringBuffer strBuf = new StringBuffer();
        strBuf.append("<select>");
        for(int i=0;i<s.length;i++)
        {
            strBuf.append("<option>");
            strBuf.append(s[i][0]);
            strBuf.append("</option>");
        }
        strBuf.append("</select>");
        out.println(strBuf);
}
于 2013-01-17T11:06:31.133 回答