使用jquery验证的Materialisecss不起作用

时间:2016-07-27 13:38:46

标签: javascript jquery ajax forms materialize

HTML标记;

<div id="address" class="col s12">
    <div class="row">
        <form method="post" action="" id="addressDetails">
            <div class="input-field col s6">
                <textarea id="lAddress" name = 'lAddress' minlength='20' maxlength='100' class="materialize-textarea" class="validate" required length="100"></textarea>
                <label for="lAddress" data-error="Must be between 20 to 100 Characters">Local Address</label>
            </div>
            <div class="input-field col s6">
                <textarea id="pAddress" name = 'pAddress' minlength='20' maxlength='100' class="materialize-textarea" class="validate" required length="100"></textarea>
                <label for="pAddress" data-error="Must be between 20 to 100 Characters">Permanent Address</label>
            </div>
        </form>
    </div>
    <div class="row center-align">
        <button type="submit" name="submitAddress" form="addressDetails" class="waves-effect waves-light light-blue darken-1 btn updateProfile">Save Address Details</button>
    </div>
</div>

JavaScript代码:

function updateProfile(event) {
    console.log(this);
    event.preventDefault();
    form = $(this).closest('.col.s12').find('form');
    $.ajax('profile/updateProfile.php', {
        type: "POST",
        dataType: "json",
        data: form.serialize(),
        success: function(result) {
            Materialize.toast(result.message, 4000);
        },
        error: function() {
            Materialize.toast("Failed: Please contact admin.", 4000);
        },
        timeout: 5000
    });
}

$(document).ready(function() {
    $("button.updateProfile").on('click', updateProfile);
});

早期正常的表单提交验证工作正常。但是现在使用jQuery AJAX请求我能够发送数据,但是当表单无效时,它会显示错误的红色,但它接受表单有错误。

当我使用$("button.updateProfile").on('sumbit', updateProfile);时,它正在验证,但它正在重新加载页面并且preventDefault无效。

1 个答案:

答案 0 :(得分:3)

$("button.updateProfile").on('click', updateProfile);

这不会在物化验证的帮助下验证。你必须寻找submit

再次提交它会有问题,它不是在寻找表单提交。

$("button.updateProfile").on('sumbit', updateProfile);

而不是按钮使用表单,然后将查找表单提交。喜欢这个

$("form").on('submit', updateProfile);

这将完美无缺。

因此,请记住,无论何时提交表单,都要在表单上提交,而不是在提交按钮上。