我在 UpdatePanel 的 GridView 中有一个 TemplateField,带有一个名为btnDelete
. 而不是标准OnClientClick="return confirm('Are you sure?')"
我想使用jQuery Dialog。
到目前为止,我能够使用btnDelete.Attributes["onclick"]
和在代码隐藏中设置 jQuery 对话框代码来设置 jQuery。但是,在我有机会单击“确认”或“取消”之前,它在所有情况下都会发回服务器。
这是它生成的 HTML:
<input type="submit" rel="Are you sure?" class="action-link delete" id="ctl00_c1_gvTransfers_ctl02_btnDelete" onclick="return function() {
$('#delete-transfer-confirm').dialog({
buttons: {
'Confirm' : function() { $(this).dialog('close'); return true; },
'Cancel' : function() { $(this).dialog('close'); return false; }
}
});
$('p.message').text($(this).attr('rel'));
$('#delete-transfer-confirm').dialog('open');
};" value="Delete" name="ctl00$c1$gvTransfers$ctl02$btnDelete">
我做错了什么导致此功能在单击任一按钮之前不会阻塞?
相反,标准确认工作得很好:
<input type="submit" class="action-link delete" id="ctl00_c1_gvTransfers_ctl02_btnDelete" onclick="try{if (!window.confirm('Are you sure?')){return false;};}catch(e1){alert("Unexpected Error:\n\n" + e1.toString());return false;};" value="Delete" name="ctl00$c1$gvTransfers$ctl02$btnDelete">
谢谢,马克
更新:
最终,我不得不使用 UseSubmitBehavior="false" 来获取要呈现的 name="" 属性。然后我不得不重写 OnClientClick,将值设置为“return;” 所以默认的 __doPostBack() 不会被执行。然后我能够连接一个 .live() 点击处理程序,它在确认时调用 __doPostBack():
$('input.delete').live('click', function(e) {
var btnDelete = $(this);
alert($(btnDelete).attr('name'));
e.preventDefault();
$('#delete-transfer-confirm').dialog({
buttons: {
'Confirm': function() {
$(this).dialog('close');
__doPostBack($(btnDelete).attr('name'), '');
return true;
},
'Cancel': function() {
$(this).dialog('close');
return false;
}
}
});
$('p.message').text($(this).attr('rel'));
$('#delete-transfer-confirm').dialog('open');
});