0

我有一个表格,用户可以在其中注册时事通讯,但我无法正确提交。

当我单击提交按钮时,我收到一条警告说“失败”,因此 ajax 请求直接进入 ajax 请求中的错误捕获。

在我的 php 中,我获取了所有 $_POST 变量并将它们插入到数据库中,我知道该脚本正在运行。我只想将消息返回给ajax成功,以便可以将消息显示给用户。

我到处寻找解决方案,但找不到。

<?php
    echo "done";
?>

和带有jquery的表格

<html>
<head>
<script type="text/javascript" src="js/jquery-1.9.0.min.js"></script>
<script type="text/javascript">
    $(document).ready(function() {

        $('#mlbutton').click(function() {

            var name = $('#mlName').val();
            var email = $('#mlEmail').val();

            $.ajax({
                type:'POST', 
                url: 'storeAddress.php',
                data:$('#addressform').serialize(),
                success: function(response) {
                    $('#addressform').find('#response').html(response);
                    alert(response);
                },
                complete: function() {
                    $('#addressform').each(function() {
                        this.reset();
                    });
                },
                error: function(){
                    alert('failure');
                }
            });
        });
    });
</script>
</head>
<body>
<form id="addressform">
    <div class="textl1"><label id="namLbl" for="mlName">Name</label><input type="text" id="mlName" name="mlName" /></div>
    <div class="textl1"><label id="emlLbl" for="mlEmail">Email</label><input type="text" id="mlEmail" name="mlEmail" /></div>
    <div class="textr1"><input type="submit" id="mlbutton" name="mlbutton" value="dffhfdh" class="button-signup" /></div>
    <p id="response" style="text-align: left"> </p>
</form>
</body>
</html>

更新

添加了 e.preventDefault(); //调用阻止默认事件

这现在停止了失败消息,但似乎没有调用 php 文件。我已经测试了 php 文件,因为没有提供电子邮件地址,所以我收到了一条我期待的消息。如果我只是单击表单而不输入电子邮件地址,我会收到相同的消息,但什么也没有。如果我确实输入了一个电子邮件地址,我希望该电子邮件在数据库中,但没有任何反应。就像没有调用php文件一样

4

2 回答 2

1

可以防止表单的默认操作。

$('#mlbutton').click(function(e) { //added event as argument
    e.preventDefault(); //call prevent default on event
    var name = $('#mlName').val();
    var email = $('#mlEmail').val();

    $.ajax({
        type:'POST', 
        url: 'storeAddress.php',
        data:$('#addressform').serialize(),
        success: function(response) {
            $('#addressform').find('#response').html(response);
            alert(response);
        },
        complete: function() {
            $('#addressform').each(function() {
                this.reset();
            });
        },
        error: function(){
            alert('failure');
        }
    });
});
于 2013-09-06T15:04:36.663 回答
1

您需要阻止您的按钮提交页面,以便 AJAX 可以运行。

$('#mlbutton').click(function(e) {
    e.preventDefault();
    ....
于 2013-09-06T15:05:00.650 回答