将地址行2 inout元素设置为可选

时间:2019-03-11 02:00:54

标签: jquery html5

我有一个html form,我正在使用Jquery来验证输入元素,但是问题是该脚本正在验证所有输入文本字段,而不是在验证选择字段。另外,我需要将地址行2输入文本字段设置为可选,并且必须选择字段。

<fieldset>
<div class="form-bottom">
    <div class="row">
        <div class="form-group col-xl-4 col-lg-4 col-md-12 col-sm-12 col-12">
            <input type="text" class="form-control" placeholder="addres 1" id="add1" name="" value="" |>
        </div>
        <div class="form-group col-xl-4 col-lg-4 col-md-12 col-sm-12 col-12">
            <input type="text" class="form-control" placeholder="address 2" id="add2" name="" value="">
        </div>
        <div class="form-group col-xl-4 col-lg-4 col-md-12 col-sm-12 col-12">
            <input type="text" class="form-control" placeholder="city" id="city" name="" value="" |>
        </div>
    </div>
    <div class="row">
        <div class="form-group col-xl-4 col-lg-4 col-md-12 col-sm-12 col-12">
            <input type="text" class="form-control" placeholder="Home Phone" id="contact_number" name="" value="">
        </div>
    </div>

  

 < script >
$(document).ready(function() {
    $('.registration-form fieldset:first-child').fadeIn('slow');

    $('.registration-form input[type="text"]').on('focus', function() {
        $(this).removeClass('input-error');
    });

    // next step
    $('.registration-form .btn-next').on('click', function() {
        var parent_fieldset = $(this).parents('fieldset');
        var next_step = true;

        parent_fieldset.find('input[type="text"],input[type="email"]').each(function() {
            if ($(this).val() == "") {
                $(this).addClass('input-error');
                next_step = false;
            } else {
                $(this).removeClass('input-error');
            }
        });

        if (next_step) {
            parent_fieldset.fadeOut(400, function() {
                $(this).next().fadeIn();
            });
        }

    });

    // previous step
    $('.registration-form .btn-previous').on('click', function() {
        $(this).parents('fieldset').fadeOut(400, function() {
            $(this).prev().fadeIn();
        });
    });

    // submit
    $('.registration-form').on('submit', function(e) {

        $(this).find('input[type="text"],input[type="email"]').each(function() {
            if ($(this).val() == "") {
                e.preventDefault();
                $(this).addClass('input-error');
            } else {
                $(this).removeClass('input-error');
            }
        });

    });

}); < /script>

1 个答案:

答案 0 :(得分:0)

如果您不想验证地址2。您可以忽略它。试试这个。

jQuery

 $('.registration-form').on('submit', function(e) {
        $(this).find('input:text[name!=add2],input[type="email"]').each(function() { // this will filter input of having name of add2
            if ($(this).val() == "") {
                e.preventDefault();
                $(this).addClass('input-error');
            } else {
                $(this).removeClass('input-error');
            }
        });

    });

HTML

   <form class="registration-form" name="register">
    <fieldset>
        <div class="form-bottom">
            <div class="row">
                <div class="form-group col-xl-4 col-lg-4 col-md-12 col-sm-12 col-12">
                    <input type="text" class="form-control" placeholder="addres 1" id="add1" name="" value="" |>
                </div>
                <div class="form-group col-xl-4 col-lg-4 col-md-12 col-sm-12 col-12">
                    <input type="text" class="form-control" placeholder="address 2" id="add2" name="add2" value="">
                </div>
                <div class="form-group col-xl-4 col-lg-4 col-md-12 col-sm-12 col-12">
                    <input type="text" class="form-control" placeholder="city" id="city" name="" value="" |>
                </div>
            </div>
            <div class="row">
                <div class="form-group col-xl-4 col-lg-4 col-md-12 col-sm-12 col-12">
                    <input type="text" class="form-control" placeholder="Home Phone" id="contact_number" name=""
                           value="">
                </div>
            </div>
        </div>
    </fieldset>
    <input type="submit" value="Submit">
</form>