我有一个网格以表格格式显示数据,如下所示。
<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()
orStringTokenizer
并将它们解析到Long
/ Integer
on服务器。
网格允许选择多行,因为multiselect
设置为true
, multiselect="true"
。