为什么jquery对话框消息不必要地刷新我的页面(在表单内)

时间:2013-05-18 23:47:03

标签: php jquery modal-dialog

我试图在表单中嵌入一个简单的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">&nbsp;</td>
    <td><input class="input" type="checkbox" name="rules" id="rules" value="1" /><button id="opener">Regeln</button></td>
  </tr>

</table>
</form>

2 个答案:

答案 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;
});