jQuery回调函数未执行

时间:2014-01-20 20:14:49

标签: php jquery json callback

我有一个带有几个输入字段和一个div作为按钮的联系表单 - 当我点击它时,它会调用一个验证表单的函数,如果一切正常则提交它。该函数将数据从输入发送到API.php文件,该文件调用BusinessLogic.php文件中的发送函数。提交表单后 - 应激活一个回调函数,它应该为确认div设置动画。

输入的HTML:

<div id="contact_inputs_block">
    <div class="div_contact_form_input_box div_input_name">
        <input type="text" name="Name" placeholder="* Name" id="name">
    </div>
    <div class="div_contact_form_input_box div_input_phone">
        <input type="tel" name="Phone" placeholder="* Phone" id="phone">
    </div>
    <div class="div_contact_form_input_box div_input_email">
        <input type="email" name="Email" placeholder="* Email" id="email">
    </div>
</div>
<div class="form_confirmation_wraper">
    <div id="div_form_confirmation">
        Message sent.
    </div>
    <div class="div_send_form">

    </div>
</div>

这是我的功能:

function submit_form(language)
{   

var email_str = $("#email").val();
var errors = new Array();

$("#contact_inputs_block>div:not(:last-child)").css({'border-color' : '#a5957e', 'background-color' : '#f8f8f8'});


if ($("#name").val()=="")
{
    errors.push(".div_input_name");
}
if(!validate_email(email_str))
{
    errors.push(".div_input_email");
}
if ($("#phone").val()=="")
{
    errors.push(".div_input_phone");
}


if (errors.length == 0)
{


    $.getJSON("inc/API.php",
    {
        command : "send_contact_form",
        name : $("#name").val(),
        email : email_str,
        phone : $("#phone").val(),
        message : $("#message").val().replace(/\n/g, '<br>'),
        form_language: language
    } ,function(){
        alert("sent");
        $("#div_form_confirmation").animate({opacity:1}, 1000, function(){
            setTimeout($("#div_form_confirmation").animate({opacity:0}, 3000, function(){location.reload()}),6000);
        }); // end callback function
    }); // end getJSON
} // end if
else
{
    for (var i = 0; i <= errors.length; i++)
    {
        $(errors[i]).css({'border-color' : '#E60005', 'background-color' : '#ffc4c9'});
    }
}
}

这是API.php中的函数:

include_once 'BusinessLogic.php';
session_start();

$command = $_REQUEST["command"];

switch($command)
{
    case "send_contact_form" :
        send_contact_form($_REQUEST["name"], $_REQUEST["email"], 
            $_REQUEST["phone"], $_REQUEST["message"], $_REQUEST["form_language"]);
        break;
}

并且BusinessLogic.php实际上发送邮件。

邮件正在发送,一切都很好。问题是submit_form()函数的回调从未被触发,我没有看到邮件被发送的确认。

为什么会发生这种情况?如何解决?谢谢!

1 个答案:

答案 0 :(得分:2)

另一种方法可能是使用$ .post而不是$ .getJSON(其他一切都将保持不变)。它将进行所需的ajax调用。定义的参数将在$ _POST数组中($ _REQUEST很好)