在加载表单并显示错误时,Parsley验证将立即开始。 如何在开始时防止这种情况?
这是我的代码:
更新:添加了HTML 我通过将data-parsley-validate =“”添加到表单标签来添加验证。当我使用parsley()函数时需要吗?哪种方法更好?
// Activate validation
$("#form_register").parsley();
// On validation
$('#form_register').parsley().whenValidate().done(function() {
$("#form_register").submit();
});
// Validate when submit button clicked
$('#form_register .btn-submit').click(function(){
$('#form_register').parsley().validate();
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://rawgit.com/guillaumepotier/Parsley.js/2.8.1/dist/parsley.js"></script>
<form id="form_register" method="post" data-parsley-validate="">
<label for="username">usename :</label>
<input type="text" name="username" id="username" class="form-control" autocomplete="username" requireddata-parsley-remote="register/ajax_username_exists/{value}" data-parsley-remote-reverse="true">
<label for="password">Password :</label>
<input type="password" name="password" id="password" class="form-control" autocomplete="new-password" required pattern="(?=^.{8,}$)((?=.*\d)|(?=.*\W+))(?![.\n])(?=.*[A-Z])(?=.*[a-z]).*$" >
<label for="repassword">Password again:</label>
<input type="password" name="repassword" id="repassword" class="form-control" required autocomplete="new-password" data-parsley-equalto="#password" >
<label for="first_name">First Name :</label>
<input type="text" name="first_name" id="first_name" class="form-control" autocomplete="name">
<label for="last_name">Last Name:</label>
<input type="text" name="last_name" id="last_name" class="form-control" autocomplete="family-name">
<label for="mobile_number">Mobile :</label>
<input type="text" name="mobile_number" id="mobile_number" class="form-control" autocomplete="mobile" pattern="^09\d{9}$" >
<label for="phone_number">Phone :</label>
<input type="text" name="phone_number" id="phone_number" class="form-control" autocomplete="tel" pattern="^\d{8,12}$" >
<label for="address">Address :</label>
<input type="text" name="address" id="address" class="form-control" autocomplete="street-address">
<label for="date_birth">Birth Date:</label>
<input type="text" name="date_birth" id="date_birth" class="form-control" autocomplete="bday" placeholder="0000-00-00" pattern="^\d{4}-\d{1,2}-\d{1,2}$" value="1975-01-01">
<input type="button" value="Register" class="btn btn-primary btn-submit">
</form>
答案 0 :(得分:0)
如果您需要示例中所示的基本验证,则无需担心events
之类的field:validated
。您可以简单地调用validate()
函数,该函数将在提交之前验证您的表单。
您必须更改提交按钮,如下所示,以便在验证成功后将提交表单。
(将类型更改为"submit"
,而不是"button"
)
<input type="submit" value="Register" class="btn btn-primary btn-submit" />
然后删除所有Javascript代码,并仅保留以下内容。
$('#form_register .btn-submit').click(function(){
$('#form_register').parsley().validate();
});
这将在您提交表单时执行验证,成功后将提交表单。
这里是一个小提琴:https://jsfiddle.net/nimeshka/nx4aLthp/38/
希望它会有所帮助:)