【问题标题】:jquery validation plugin with ajax submit handler not working带有ajax提交处理程序的jquery验证插件不起作用
【发布时间】:2013-12-15 17:52:29
【问题描述】:

在过去的几天里,我使用了很多 jquery 验证插件,但还没有将它与 ajax 提交一起使用。我所拥有的内容被缩减为两个字段。提交时值没有错误。单击提交按钮时,不会发生任何提交。它什么也不做。

HTML:

<form id="account-info-form" action="/process/p_profile_info.php" method="post">
    <div class="row margin-bottom-20">
        <div class="col-md-6 form-group">
            <label>First Name</label>
            <div class="input-group">
                <span class="input-group-addon">
                    <i class="fa fa-user fa-fw"></i>
                </span>
                <input class="form-control" type="text" name="fname"/>
            </div>
        </div>
        <div class="col-md-6 form-group">
            <label>Last Name</label>
            <div class="input-group">
                <span class="input-group-addon">
                    <i class="fa fa-user fa-fw"></i>
                </span>
                <input class="form-control" type="text" name="lname"/>
            </div>
        </div>
    </div>
    <div class="row margin-bottom-30">
        <div class="col-md-12">
            <button class="btn btn-primary" type="submit" name="account-info" value="save"><i class="fa fa-check-circle"></i> Save Changes</button>
            <button class="btn btn-default" type="reset">Cancel</button>
        </div>
    </div>
</form>

JS:

$('#account-info-form').validate({          
    // ajax submit
    submitHandler: function (form) {
    var $form = $(this);
        $.ajax({
            type: $form.attr('method'),
            url: $form.attr('action'),
            data: $form.serialize(),
            dataType : 'json'
        })
        .done(function (response) {
            if (response.success == 'success')
            {               
        alert('success');                       
            } 
            else
            {
                alert('fail');
            }
        });
    return false; // required to block normal submit since you used ajax
    }
});

【问题讨论】:

    标签: php jquery ajax jquery-validate


    【解决方案1】:

    没有理由这样做,($(this) 不是您所期望的)...

    var $form = $(this);
    

    只需使用传递给函数的form 参数。

    submitHandler: function (form) {
        $.ajax({
            type: $(form).attr('method'),
            url: $(form).attr('action'),
            data: $(form).serialize(),
            dataType : 'json'
        })
        .done(function (response) {
            if (response.success == 'success') {               
                alert('success');                       
            } else {
                alert('fail');
            }
        });
        return false; // required to block normal submit since you used ajax
    }
    

    【讨论】:

    • doh... 我发誓我一开始就有这个,但我一定是在使用 $form 什么的。再次感谢!
    猜你喜欢
    • 2015-07-03
    • 2013-03-15
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2015-06-27
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多