javascript - jQuery ajax : how to destroy submit if ajax validation fails?

标签 javascript jquery

我在用户设置区域中有电子邮件字段。当然,所有电子邮件都是唯一的,因此我需要在提交表单之前检查电子邮件是否未被其他人使用。

代码如下:

var email = $("input#email-id").val();

$("#form-id").submit(function(){
    $.ajax({
        url: "/ajax/email?email=" + email,
        success: function(data){
            if(data != 'ok'){
                alert("Email is used already");
                return false;
            }
        }
    });
});

因此,如果 data 不是 'ok',它必须破坏提交表单,因为 if() 返回 false,但它没有,表单照常提交,甚至没有出现警报!

我已经检查了 ajax 答案,它工作正常(如果使用电子邮件,则返回 'user_already')。 那我做错了什么?

谢谢!

最佳答案

因为 ajax 本质上是异步的,所以你不能那样做。如果你真的想这样做,你可以在成功处理程序中提交表单。试试这个。

function submitHandler(){
    var email = $("input#email-id").val();

    $.ajax({
        url: "/ajax/email?email=" + email,
        success: function(data){
            if(data != 'ok'){
                alert("Email is used already");
                return false;
            }
            else{
               //Once the data is ok you can unbind the submit handler and 
               //then submit the form so that the handler is not called this time
               $("#form-id").unbind('submit').submit();
            } 
        }
    });
    return false;//This will prevent the form to submit
}
$("#form-id").submit(submitHandler);

关于javascript - jQuery ajax : how to destroy submit if ajax validation fails?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8855505/

相关文章:

javascript - 静态管理自定义输入

javascript - 如何防止响应式网站截图?

Javascript 月份翻译对象

javascript - React 钩子(Hook)需要返回一个值吗?

javascript - (cordova) (inappbrowser) 让用户知道你正在准备他们的页面

javascript - 想要在页面加载时显示类似 YouTube 的进度条

javascript - 检查屏幕上是否有任何移动或键盘上是否有点击

javascript - 如何通过 AngularJS 复选框进行过滤?

javascript - 加载并单击时隐藏/显示 div

javascript - jQuery addClass 或 css 在特定条件下不起作用