我使用的是子网格。我会点击子网格中的链接"添加会话",它会将行添加到子网格中。我可以添加n行。现在,我需要验证子网格中添加的每一行。我怎么能那样做?
我正在下面粘贴我的代码。。。
//This is my jqgrid code:
function loadSubGrid(subgrid_id, row_id) {
DayID = $('#DayEvents').getCell(row_id, 'DayID');
var 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><a href=# id='AddSession' OnClick='addRow("" + subgrid_table_id + "");'>add session</a><div id='" + pager_id + "' class='scroll'></div>");
jQuery("#" + subgrid_table_id).jqGrid({
url: 'Event.asmx/GetSubGridDay',
datatype: 'json',
mtype: 'POST',
cellEdit: false,
cellsubmit: 'clientarray',
onCellSelect: GridCellClick,
ajaxGridOptions: { contentType: 'application/json; charset=utf-8' },
serializeGridData: PrepareGridPostData,
jsonReader: { repeatitems: false, root: "d.rows", page: "d.page", total: "d.total", records: "d.records" },
colNames: ['sessionId', 'session', 'start time', 'end time', 'Speaker'],
colModel:
[{ name: 'SessionId', index: 'SessionId', width: 90, formatter: 'text', align: 'center', hidden: true },
{ name: 'SessionName', index: 'SessionName', width: 90, formatter: 'text', align: 'center', edittype: 'text', editable: true, editoptions: { size: 10, maxlength: 15, dataEvents: [{ type: 'change', fn: GetRemainingEffort }, { type: 'focus', fn: clearCellValues }, { type: 'blur', fn: resetCellValues}]} },
{ name: 'StartTime', index: 'StartTime', width: 90, formatter: 'text', align: 'center', edittype: 'text', editable: true, editoptions: { size: 10, maxlength: 15, dataInit: function(element) {
$(element).timepicker({})
}, dataEvents: [{ type: 'change', fn: GetRemainingEffort }, { type: 'focus', fn: clearCellValues }, { type: 'blur', fn: resetCellValues}]}
},
{ name: 'EndTime', index: 'EndTime', width: 90, formatter: 'text', align: 'center', edittype: 'text', editable: true, editoptions: { size: 10, maxlength: 15, dataInit: function(element) {
$(element).timepicker({})
}, dataEvents: [{ type: 'change', fn: GetRemainingEffort }, { type: 'focus', fn: clearCellValues }, { type: 'blur', fn: resetCellValues}]}
},
{ name: 'Speaker', index: 'Speaker', width: 300, editable: false, formatter: 'showlink', formatoptions: { baseLinkUrl: 'javascript:', showAction: "Speaker('", addParam: "');"} },
],
rowNum: 10,
height: 'auto',
autowidth: true
});
}
现在,在上面代码的这一行中,它调用了一个函数来打开一个对话框。。
{ name: 'Speaker', index: 'Speaker', width: 300, editable: false, formatter: 'showlink', formatoptions: { baseLinkUrl: 'javascript:', showAction: "Speaker('", addParam: "');"} },
打开对话框的功能如下:
function Speaker() {
$("#SpeakerPopUp").dialog('open');
$("#SpeakerPopUp").dialog(
{
autoOpen: true,
height: 500,
width: 500,
modal: true,
title: 'Speakers List',
open: gridData,
buttons: {
'cancel': function CancelCheck() { $(this).dialog('close'); },
'Save': SpeakerSelectionSave
}
});
}
}
现在我需要的是,如果子网格行中的任何一列为空,它不应该打开对话框。。请帮帮我。。希望我能清楚地解释我的需求。。
只需在函数扬声器中的$("#SpeakerPopUp").dialog('open')之前插入以下行;
if (_lastSelRow == null) { alert("enter all"); }
else {
alert("test" + _lastSelRow);
if (($('#' + _lastSelRow + '_SessionName').val() == "") || ($('#' + _lastSelRow + '_StartTime').val() == "") || ($('#' + _lastSelRow + 'EndTime').val() == ""))
else
{
///