为什么我的jQuery事件没有阻止帖子?

Rya*_*yan 2 asp.net-mvc jquery

我有一个MVC应用程序,它使用自己的用户数据库和身份验证系统,而不是标准的帐户控制器和aspnet auth系统(没有计划改变它).作为其中的一部分,我有一个jQuery事件,在发送到服务器的表单发布之前检查是否存在用户名以创建新用户.当我在.submit函数的开头放置一个event.preventDefault时,一切似乎都正常工作.但是,如果用户名已存在,我只想阻止帖子.在下面的例子中,我从未收到过警报,并且发布了帖子任何人都可以告诉我我做错了什么?谢谢!

    $(document).ready(function () {
        $('#ProcessApplication').submit(function (event)
        {                                             
            var un = encodeURIComponent($("input[name='form_email1']").val());
            var myurl = '/Home/IsUser/' + un;
            alert(myurl);
            $.ajax({
                url: myurl,
                success: function (response) {
                    if (response == '1') {                           
                        alert("This e-mail address is already registered. Please login, then resubmit your application.");
                        event.preventDefault(); // <-- I've tried both event.preventDefault(); and return false; here
                    }
                }
            });                
        });
    });   
Run Code Online (Sandbox Code Playgroud)

Arc*_*her 5

你只需要preventDefault()你的函数中的早期...

$(document).ready(function () {
    $('#ProcessApplication').submit(function (event) {                                             
        event.preventDefault(); // <-- Put it here
        var un = encodeURIComponent($("input[name='form_email1']").val());
        var myurl = '/Home/IsUser/' + un;
        alert(myurl);
        $.ajax({
            url: myurl,
            success: function (response) {
                if (response == '1') {                           
                    alert("This e-mail address is already registered. Please login, then resubmit your application.");
                }
            }
        });                
    });
});  
Run Code Online (Sandbox Code Playgroud)

你拥有它的地方只是在ajax调用完成后被调用,这将在提交后发生.