使用Struts2-grid插件收集/捕获已检查行的ID数组以删除行

时间:2014-03-06 14:18:28

标签: jsp struts2 struts2-jquery struts2-jquery-grid

我有一个网格,以表格格式显示数据如下。

<s:url id="remoteurl" action="SizeGrid" namespace="/admin_side"/>
<s:url id="editurl" action="SizeCRUD" namespace="/admin_side"/>

<sjg:grid
    id="gridmultitable"
    caption="Size"
    dataType="json"
    href="%{remoteurl}"
    pager="true"
    navigator="true"
    navigatorSearchOptions="{sopt:['eq','ne','lt','gt']}"
    navigatorEdit="false"
    navigatorView="false"
    navigatorAddOptions="{height:280, width:500, reloadAfterSubmit:true}"
    navigatorEditOptions="{height:280, width:500, reloadAfterSubmit:false}"
    navigatorViewOptions="{height:280, width:500}"
    navigatorDelete="true"
    navigatorDeleteOptions="{height:280, width:500,reloadAfterSubmit:true}"
    gridModel="gridModel"
    rowList="5,10,15"
    rowNum="5"
    rownumbers="true"
    editurl="%{editurl}"
    editinline="true"
    multiselect="true"
    onClickGroupTopics="rowdelete"
    onSelectRowTopics="rowselect"
    onEditInlineSuccessTopics="oneditsuccess"
    viewrecords="true"
    shrinkToFit="false"
    width="1045"
    >

    <sjg:gridColumn name="sizeId" index="sizeId" title="%{getText('size.title.id')}" key="true" frozen="true" width="200" editable="false" dataType="Long" sortable="true" search="true" sorttype="integer" searchoptions="{sopt:['eq','ne','lt','gt']}"/>
    <sjg:gridColumn name="sizeCode" index="sizeCode" title="%{getText('size.title.code')}" editrules="{required: true}" width="780" editable="true" sortable="true" search="true" sorttype="text"/>

</sjg:grid>

<s:hidden name="idArray"/>

单击删除链接时,我希望将所选行的ids(在这种情况下为sizeId)作为数组传递。

为此,需要在触发删除行的实际请求之前调用JavaScript函数。

我尝试过以下原始/不完整的JavaScript函数。

$.subscribe('rowdelete', function(event, data){
    var checks=$("#gridmultitable").find('input[type=checkbox]');
    var idArray =new Array();
    alert(checks.length);

    for(var i=0;i<checks.length;i++)
    {
        if(checks[i].checked)
        {
            var sizeId = checks[i].parentNode.parentNode;
            var id=sizeId.id;

            idArray.push($("#gridmultitable").jqGrid('getCell',id,'cellvalue'));
        }
    }
    document.getElementById("idArray").value=idArray; 
});

但是从不调用此函数。

是否有办法收集所选/已检查行的ids(在这种情况下为sizeId),以便它们可以作为数组提供,因为ids以逗号形式传递分隔字符串,我不喜欢使用String#split()StringTokenizer之类的函数收集它们,并将它们解析为服务器上的Long / Integer

网格允许选择多行,因为multiselect设置为truemultiselect="true"

1 个答案:

答案 0 :(得分:0)

对于selected/checked rows部分,here是基础网格项目api。对于multiselect=true,您可以通过

将所选行的ID检索为数组
$("#gridmultitable").jqGrid("getGridParam","selarrrow");