在表单上有4个文本输入 如果其中至少有一个具有值,则所有剩余字段必须具有值 是否可以为此验证配置Parsley.js?
答案 0 :(得分:6)
是的,有可能。但是,没有默认配置可以执行此操作。
这意味着您必须在javascript中创建该逻辑并在每种情况下销毁/绑定欧芹。
看一下这段代码(jsfiddle available):
<form class="form-inline" method="post" id="myForm">
<input type="text" id="field1" name="field1" />
<input type="text" id="field2" name="field2" />
<input type="text" id="field3" name="field3" />
<input type="text" id="field4" name="field4" />
<button type="submit" class="btn btn-default">test</button>
</form>
<script>
$('#myForm').parsley();
$("#field1, #field2, #field3, #field4").on('change', function() {
if ($("#field1").val().length > 0 ||
$("#field2").val().length > 0 ||
$("#field3").val().length > 0 ||
$("#field4").val().length > 0 )
{
// If any field is filled, set attr required
$("#field1, #field2, #field3, #field4").attr("required", "required");
} else {
// if all fields are empty, remove required attr
$("#field1, #field2, #field3, #field4").removeAttr("required");
}
// destroy ParsleyForm instance
$('#myForm').parsley().destroy();
// bind parsley
$('#myForm').parsley();
});
$("#myForm" ).on('submit', function( event ) {
$(this).parsley().validate();
if ($(this).parsley().isValid()) {
alert('form is valid');
}
event.preventDefault();
});
</script>