如果4个字段中的1个具有值,则验证Parsley.js

时间:2014-11-16 15:05:01

标签: javascript html validation parsley.js

在表单上有4个文本输入 如果其中至少有一个具有值,则所有剩余字段必须具有值 是否可以为此验证配置Parsley.js?

1 个答案:

答案 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>