1

我有一个用于注册新用户的简单表格。我想阻止用户再次提交相同的电子邮件 ID。因此,在提交表单之前,我想做一个 Ajax 检查电子邮件 ID 是否存在。如果电子邮件 ID 存在,我会提醒用户。如果没有,我让表单提交。

$("#sign_in_form").submit(function(event){ 

event.preventDefault();
$.post("http://xyz.com/check_if_user_exists", {
        email : $("#contact_person_email").val()
    }).done(function(data) {

var res = parseInt(data);
if(res==1){

//Email Exists
alert("Email exists . Please use different email " );
return false; //----------------------------1)

}else{
  //Email doesnt exist
return true;   //--------------------------- 2)
}

});

//end of function

});

这段代码的问题是由于 Javascript 的异步特性,函数甚至在 ajax post 语句返回结果之前就结束了。因此 1) 和 2) 处的 return false 或 return true 语句无效。处理这个的正确方法是什么?

4

1 回答 1

3

如果检查有效,则使用 js 原生事件提交表单:

$("#sign_in_form").submit(function (event) {

    event.preventDefault();
    $.post("http://xyz.com/check_if_user_exists", {
        email: $("#contact_person_email").val()
    }).done(function (data) {

        var res = parseInt(data);
        if (res == 1) {

            //Email Exists
            alert("Email exists . Please use different email ");

        } else {
            document.getElementById('sign_in_form').submit();
        }

    });

    //end of function

});
于 2013-06-29T13:28:27.490 回答