我试图在表单中嵌入一个简单的jquery对话框消息。该对话框应该只显示一些附加信息,并且不会以任何方式与表单交互,除非通过表单内部的按钮调用。
我的问题如下:如果从表单内部调用对话框,整个页面会立即刷新,根本不显示对话框并清除所有表单字段。如果按钮在表单之外,一切正常。
正在通过以下模板加载对话框内容:
<script>
$(function() {
var dlg = $( "#dialog-message" ).dialog({
autoOpen: false,
width: '80%',
closeOnEscape: false,
modal: true,
buttons: {
Ok: function() {
$( this ).dialog( "close" );
}
},
open: function() {
// Content laden...
$("#dialog-message").load('template.html', function() {}).dialog()
}
});
$( "#opener" ).click(function() {
$( "#dialog-message" ).dialog( "open" );
});
});
</script>
表单集成:
<form method="post" name="post" action="index.php?site=bewerbung">
<table width="100%" border="0" cellspacing="1" cellpadding="2" bgcolor="$border">
...
</tr>
<tr bgcolor="$bg1">
<td height="25"> </td>
<td><input class="input" type="checkbox" name="rules" id="rules" value="1" /><button id="opener">Regeln</button></td>
</tr>
</table>
</form>
答案 0 :(得分:0)
您的按钮提交表单,因此您需要通过JavaScript阻止默认按钮操作:
$("#opener").on('click', function(e) {
dlg.dialog("open");
e.preventDefault();
});
您没有提到您正在使用的jQuery(UI)版本。我上面的代码适用于较新的版本。 这是demo。
答案 1 :(得分:0)
通常对于按钮和提交输入:如果放置“return false”,则可以阻止刷新页面在你的功能结束。在你的情况下
$( "#opener" ).click(function() {
$( "#dialog-message" ).dialog( "open" );
return false;
});