jQuery検証プラグインを使用したブートストラップ


154

jQuery Validation Pluginを使用してフォームに検証を追加しようとしていますが、入力グループを使用しているときにプラグインがエラーメッセージを表示するという問題があります。

問題

$('form').validate({
    rules: {
        firstname: {
            minlength: 3,
            maxlength: 15,
            required: true
        },
        lastname: {
            minlength: 3,
            maxlength: 15,
            required: true
        }
    },
    highlight: function(element) {
        $(element).closest('.form-group').addClass('has-error');
    },
    unhighlight: function(element) {
        $(element).closest('.form-group').removeClass('has-error');
    }
});

私のコード: http : //jsfiddle.net/hTPY7/4/


私はこれを見つけたと思いますし、私は最後のブートストラップ3とアプリ継承されたときに年前にそれをブックマークしていたことを笑った/ブートストラップ3ワットアプリ、継承されています
エイドリアン・J・モレノ

回答:


347

twitterブートストラップ3との完全な互換性のために、いくつかのプラグインメソッドをオーバーライドする必要があります。

// override jquery validate plugin defaults
$.validator.setDefaults({
    highlight: function(element) {
        $(element).closest('.form-group').addClass('has-error');
    },
    unhighlight: function(element) {
        $(element).closest('.form-group').removeClass('has-error');
    },
    errorElement: 'span',
    errorClass: 'help-block',
    errorPlacement: function(error, element) {
        if(element.parent('.input-group').length) {
            error.insertAfter(element.parent());
        } else {
            error.insertAfter(element);
        }
    }
});

例を参照してください:http : //jsfiddle.net/mapb_1990/hTPY7/7/


1
すばらしい、$(element).removeClass(errorClass);を追加することについて言及したかっただけです。強調表示を解除して$(element).addClass(errorClass); ブートストラップヘルプブロッククラスを使用しないようにしたい場合にハイライト
Jay Rizzi 2013年

3
これは1つの点を除いてうまく機能します。jQueryValidate 1.11.1に対してテストresetForm()し、フォームのバリデーターを呼び出してもunhighlight、無効な要素は呼び出されないため、has-errorフォームをリセットするときに手動でクラスを削除する必要があります。私は何をしてバリデータを呼び出すのではなく、次の関数を呼び出すことですですresetForm()直接:function resetForm(form_id) { $(form_id).find(".form-group").removeClass("has-error"); $(form_id).data('validator').resetForm(); }
エイドリアンロペス

なぜコードが私のフォームで機能しないのかわかりません:(
Alyssa Reyes

陽気でそれは魅力のように働きます!本当にありがとう!!! あなたは私に潜在的に1、2時間の研究を救ってくれました。
racl101 2014

1
:あなたがブートストラップ示唆(ラジオ入力はラベル・タグの内側に配置される)のようなラジオボタンを使用している場合は、ブロック場合にこのような何かを追加したいと思うelse if (element.prop('type') === 'radio') { error.insertBefore(element.parent().parent()); }
エリオット・キャメロン

86

Bootstrap 3との完全な互換性のために、他のソリューションにはなかったinput-groupradio、およびcheckboxのサポートを追加しました。

2017年10月20更新:他の回答の候補を調査しradio-inlineの特別なマークアップのサポートを追加し、ラジオまたはチェックボックスのグループのエラー配置を改善し、コントロールの検証を防ぐためのカスタム.novalidationクラスのサポートを追加しました。これがお役に立てば幸いです。

検証プラグインを含めた後、次の呼び出しを追加します。

$.validator.setDefaults({
    errorElement: "span",
    errorClass: "help-block",
    highlight: function (element, errorClass, validClass) {
        // Only validation controls
        if (!$(element).hasClass('novalidation')) {
            $(element).closest('.form-group').removeClass('has-success').addClass('has-error');
        }
    },
    unhighlight: function (element, errorClass, validClass) {
        // Only validation controls
        if (!$(element).hasClass('novalidation')) {
            $(element).closest('.form-group').removeClass('has-error').addClass('has-success');
        }
    },
    errorPlacement: function (error, element) {
        if (element.parent('.input-group').length) {
            error.insertAfter(element.parent());
        }
        else if (element.prop('type') === 'radio' && element.parent('.radio-inline').length) {
            error.insertAfter(element.parent().parent());
        }
        else if (element.prop('type') === 'checkbox' || element.prop('type') === 'radio') {
            error.appendTo(element.parent().parent());
        }
        else {
            error.insertAfter(element);
        }
    }
});

これは、すべてのBootstrap 3フォームクラスで機能します。水平フォームを使用する場合は、次のマークアップを使用する必要があります。これにより、ヘルプブロックテキストがform-groupの検証状態( "has-error"など)を尊重することが保証されます。

<div class="form-group">
    <div class="col-lg-12">
        <div class="checkbox">
            <label id="LabelConfirm" for="CheckBoxConfirm">
                <input type="checkbox" name="CheckBoxConfirm" id="CheckBoxConfirm" required="required" />
                I have read all the information 
            </label>
        </div>
    </div>
</div>

1
微調整したerrorClass: "help-block error-help-block"。私はすでに通常のヘルプ情報に.help-blockを使用しており、これはフォーム検証メッセージで上書きされていました。2番目のクラスを追加すると、クラスが一意になり、「実際の」ヘルプメッセージが上書きされるのではなく、追加されます。
スコットスタッフォード

Hilightメソッドは呼び出されません
VladoPandžić2016年

こんにちはVlado、それがあなたにとってうまくいかない理由をもう少し詳しく教えてもらえますか?
Andreas Krohn 2016年

ラジオボタンのグループの場合、奇妙に見える最初のオプションの下にエラーメッセージが追加されます。ラジオボタンを別の方法で処理するために、これを微調整する必要があります。
エリオットキャメロン

ミスター@AndreasKrohn ^ _ ^をありがとうございました
Jeancarlo Fontalvo 2016

23

私はTwitter Bootstrap 3でのみ設計されたフォームを使用しています。バリデーターのデフォルト関数を設定し、ルール付きの検証メソッドのみを実行します。私はFontAweSomeのアイコンを使用していますが、ドキュメントの例のようにグリフィコンを使用できます。

ここに画像の説明を入力してください

jQuery.validator.setDefaults({
    highlight: function (element, errorClass, validClass) {
        if (element.type === "radio") {
            this.findByName(element.name).addClass(errorClass).removeClass(validClass);
        } else {
            $(element).closest('.form-group').removeClass('has-success has-feedback').addClass('has-error has-feedback');
            $(element).closest('.form-group').find('i.fa').remove();
            $(element).closest('.form-group').append('<i class="fa fa-exclamation fa-lg form-control-feedback"></i>');
        }
    },
    unhighlight: function (element, errorClass, validClass) {
        if (element.type === "radio") {
            this.findByName(element.name).removeClass(errorClass).addClass(validClass);
        } else {
            $(element).closest('.form-group').removeClass('has-error has-feedback').addClass('has-success has-feedback');
            $(element).closest('.form-group').find('i.fa').remove();
            $(element).closest('.form-group').append('<i class="fa fa-check fa-lg form-control-feedback"></i>');
        }
    }
});

できました。検証機能を実行した後:

$("#default-register-user").validate({
    rules: {
        'login': {
            required: true,
            minlength: 5,
            maxlength: 20
        },
        'email': {
            required: true,
            email: true,
            minlength: 5,
            maxlength: 100
        },
        'password': {
            required: true,
            minlength: 6,
            maxlength: 25
        },
        'confirmpassword': {
            required: true,
            minlength: 5,
            maxlength: 25,
            equalTo: "#password"
        }
    }
});

JSFiddleの例


1
このためのJSFiddleがあればすばらしいでしょう
kofifus

スクリーンショットに使用したHTMLを投稿してください。フィドルの例には、赤いスタイルのエラーメッセージもアイコンもありません。ありがとう!
クリストファーフランシスコ

クリストファー・フランシスコ、JSFiddleの例を更新し、フォントの素晴らしいcssを追加しました。
DARK_DIESEL

こんにちは素晴らしい解決策!ルールを含むフィールドのみが成功または失敗のメッセージを表示するように、これをどのように編集しますか?正しいコードでは、ルールがあるかどうかに関係なく、すべてのフィールドにcssが表示されます
Michael Smith

解決策は、ルールのすぐ上に「ignore: ".ignore、:hidden"」を追加することです。次に、検証しないすべてのフィールドに 'ignore'クラスを追加します
Michael Smith

10

上記のMiguel Borgesの回答に追加すると、強調表示/非強調表示のコードブロックに次の行を追加することで、ユーザーにグリーン成功のフィードバックを提供できます。

    highlight: function(element) {
        $(element).closest('.form-group').removeClass('has-success').addClass('has-error');
    },
    unhighlight: function(element) {
        $(element).closest('.form-group').removeClass('has-error').addClass('has-success');
    }

8

これが必要な解決策です。errorPlacementメソッドを使用して、エラーメッセージを配置する場所をオーバーライドできます。

$('form').validate({
    rules: {
        firstname: {
            minlength: 3,
            maxlength: 15,
            required: true
        },
        lastname: {
            minlength: 3,
            maxlength: 15,
            required: true
        }
    },
    errorPlacement: function(error, element) {
        error.insertAfter('.form-group'); //So i putted it after the .form-group so it will not include to your append/prepend group.
    }, 
    highlight: function(element) {
        $(element).closest('.form-group').addClass('has-error');
    },
    unhighlight: function(element) {
        $(element).closest('.form-group').removeClass('has-error');
    }
});

それは魔法のように私のために働きます。乾杯


error.insertAfter('.form-group');すべての.form-groupにエラーを配置します。しかし、それは私にアイデアを示しました。ありがとう
ミゲルボルヘス

5

ブートストラップ4の場合、この作業は私にとって良い

    $.validator.setDefaults({
    highlight: function(element) {
        $(element).closest('.form-group').find(".form-control:first").addClass('is-invalid');
    },
    unhighlight: function(element) {
        $(element).closest('.form-group').find(".form-control:first").removeClass('is-invalid');
        $(element).closest('.form-group').find(".form-control:first").addClass('is-valid');

    },
    errorElement: 'span',
    errorClass: 'invalid-feedback',
    errorPlacement: function(error, element) {
        if(element.parent('.input-group').length) {
            error.insertAfter(element.parent());
        } else {
            error.insertAfter(element);
        }
    }
});

それが役に立てば幸い!


これは箱から出してうまく動作します!私が追加した唯一のものはvalidClass: 'valid-feedback'
Simon Zyx

おかげで、これは、validClass: 'valid-feedback'を使用したBootstrap 4でうまく機能しました。
Zaki Mohammed

4

これが検証をフォームに追加するときに使用するものです。

// Adding validation to form.
        $(form).validate({
            rules: {
                title: {
                    required: true,
                    minlength: 3,
                },
                server: {
                    ipAddress: true,
                    required: true
                }   
            },
            highlight: function(element) {
                $(element).closest('.form-group').removeClass('has-success').addClass('has-error');
            },
            success: function(element) {
                $(element).closest('.form-group').removeClass('has-error').addClass('has-success');
            },
            errorClass: 'help-block'
        });

これは、jquery検証ライブラリーを使用する場合のBootstrap 3のスタイル設定で私に役立ちました。


3

私はこれをラジオに使用しました:

    if (element.prop("type") === "checkbox" || element.prop("type") === "radio") {
        error.appendTo(element.parent().parent());
    }
    else if (element.parent(".input-group").length) {
        error.insertAfter(element.parent());
    }
    else {
        error.insertAfter(element);
    }

このようにして、エラーは最後のラジオオプションの下に表示されます。


鮮やかに簡単な答え、ありがとう-私の既存のerrorPlacementロジックに余分なタイプの句をスロット
theotherdy

3

私はこの質問がBootstrap 3に関するものであることを知っていますが、Bootstrap 4に関連する質問が重複してこの質問にリダイレクトされるため、Bootstrap 4互換のスニペットを次に示します。

$.validator.setDefaults({
    highlight: function(element) {
        $(element).closest('.form-group').addClass('has-danger');
    },
    unhighlight: function(element) {
        $(element).closest('.form-group').removeClass('has-danger');
    },
    errorElement: 'small',
    errorClass: 'form-control-feedback d-block',
    errorPlacement: function(error, element) {
        if(element.parent('.input-group').length) {
            error.insertAfter(element.parent());
        } else if(element.prop('type') === 'checkbox') {
            error.appendTo(element.parent().parent().parent());
        } else if(element.prop('type') === 'radio') {
            error.appendTo(element.parent().parent().parent());
        } else {
            error.insertAfter(element);
        }
    },
});

いくつかの違いは次のとおりです。

  • has-danger代わりにクラスを使用するhas-error
  • ラジオとチェックボックスの位置決めエラーの改善

Bootstrap 4には.has-*クラスがなくなりました。getbootstrap.com/docs/4.3/migration/#forms-1
フレッド

2

ブートストラップ4のベータ版では、ブートストラップのアルファ版とベータ版(およびブートストラップ3)の間でいくつかの大きな変更がありました。フォームの検証に関して。

最初に、アイコンを正しく配置するには、ブートストラップ3にあったものと同等のスタイルを追加する必要があります。

.fa.valid-feedback,
.fa.invalid-feedback {
    position: absolute;
    right: 25px;
    margin-top: -50px;
    z-index: 2;
    display: block;
    pointer-events: none;
}

.fa.valid-feedback {
    margin-top: -28px;
}

ベータ版は、投稿されたコードが反映しないクラスではなく、コントロールの「状態」を使用するため、クラスも変更されたため、上記のコードは機能しない可能性があります。とにかく、成功またはハイライト/ハイライト解除のコールバックのいずれかで、フォームに「was-validated」クラスを追加する必要があります

$(element).closest('form').addClass('was-validated');

フォームコントロールのヘルプテキストに新しい要素とクラスを使用することもお勧めします

errorElement: 'small',
errorClass: 'form-text invalid-feedback',

1

これはフィールドを構成します

 $("#form_questionario").validate({
                debug: false,
                errorElement: "span",
                errorClass: "help-block",
                highlight: function (element, errorClass, validClass) {
                    $(element).closest('.form-group').addClass('has-error');
                },
                unhighlight: function (element, errorClass, validClass) {
                    $(element).closest('.form-group').removeClass('has-error');
                },
                errorPlacement: function (error, element) {
                    if (element.parent('.input-group').length || element.prop('type') === 'checkbox' || element.prop('type') === 'radio') {
                        error.insertBefore(element.parent());
                    } else {
                        error.insertAfter(element);
                    }
                },
                // Specify the validation rules
                rules: {
                        'campo1[]': 'required',
                        'campo2[]': 'required',
                        'campo3[]': 'required',
                        'campo4[]': 'required',
                        'campo5[]': 'required'
                        },

                submitHandler: function (form) {
                    form.submit();
                }
            });

1

このhttps://stackoverflow.com/a/18754780/966181に無線インライン修正を追加します

$.validator.setDefaults({
    highlight: function(element) {
        $(element).closest('.form-group').addClass('has-error');
    },
    unhighlight: function(element) {
        $(element).closest('.form-group').removeClass('has-error');
    },
    errorElement: 'span',
    errorClass: 'help-block',
    errorPlacement: function(error, element) {
        if(element.parent('.input-group').length) {
            error.insertAfter(element.parent());
        } else if (element.parent('.radio-inline').length) {
            error.insertAfter(element.parent().parent());
        } else {
            error.insertAfter(element);
        }
    }
});

シンプルでとても役に立ちます。ありがとうございました。
Chofoteddy

0

DARK_DIESELの答えは私にとってはうまくいきました。これは、グリフィコンを使用して同等のものを必要とする人のためのコードです:

jQuery.validator.setDefaults({
    highlight: function (element, errorClass, validClass) {
        if (element.type === "radio") {
            this.findByName(element.name).addClass(errorClass).removeClass(validClass);
        } else {
            $(element).closest('.form-group').removeClass('has-success has-feedback').addClass('has-error has-feedback');
            $(element).closest('.form-group').find('span.glyphicon').remove();
            $(element).closest('.form-group').append('<span class="glyphicon glyphicon-remove form-control-feedback" aria-hidden="true"></span>');
        }
    },
    unhighlight: function (element, errorClass, validClass) {
        if (element.type === "radio") {
            this.findByName(element.name).removeClass(errorClass).addClass(validClass);
        } else {
            $(element).closest('.form-group').removeClass('has-error has-feedback').addClass('has-success has-feedback');
            $(element).closest('.form-group').find('span.glyphicon').remove();
            $(element).closest('.form-group').append('<span class="glyphicon glyphicon-ok form-control-feedback" aria-hidden="true"></span>');
        }
    }
});

0

このサンプルコードを使用してみてください。Jquery検証プラグインと追加メソッドの使用。これは私のプロジェクトの作業コードです。これがあなたを助けることを願っています

//jquery validation booking page
	
	// Wait for the DOM to be ready
$(function() {
  // Initialize form validation on the registration form.
  // It has the name attribute "registration"
  $("form[name='book']").validate({
	  //on key up validation
	  onkeyup: function(element) {
      $(element).valid(); 
    },  
    // Specify validation rules
    rules: {
      // The key name on the left side is the name attribute
      // of an input field. Validation rules are defined
      // on the right side
      fname: {
        required: true,
        lettersonly: true
        },
      lname:{
        required: true,
        lettersonly: true
        },
      email: {
        required: true,
        // Specify that email should be validated
        // by the built-in "email" rule
        email: true
      },
      password: {
        required: true,
        minlength: 5
      }
    },
    // Specify validation error messages
    messages: {
      fname: {
      required:"Please enter your firstname",
      lettersonly:"Letters allowed only"
      },
      lname: {
      required:"Please enter your lastname",
      lettersonly:"Letters allowed only"
      },
      email: "Please enter a valid email address"
    },
    // Make sure the form is submitted to the destination defined
    // in the "action" attribute of the form when valid
    submitHandler: function(form) {
      form.submit();
    }
  });
});
.error {
  color: red;
  margin-left: 5px;
  font-size:15px;
}
<script src="design/bootstrap-3.3.7-dist/js/jquery.validate.js"></script>
<script src="design/bootstrap-3.3.7-dist/js/additional-methods.js"></script>

<form name="book" id="book" action="" method="post">

    <div class="row form-group">
        <div class="col-md-6 ">
            <label class="" for="fname">First Name</label>
            <input type="text" name="fname" id="fname" class="form-control" placeholder="First Name">
        </div>
        <div class="col-md-6">
            <label class="" for="lname">Last Name</label>
            <input type="text" name="lname" id="lname" class="form-control" placeholder="Last Name">
        </div>
    </div>

    <div class="row form-group">
        <div class="col-md-6 ">
            <label class="" for="date">Date</label>
            <input type="text" id="date" class="form-control datepicker px-2" placeholder="Date of visit">
        </div>
        <div class="col-md-6">
            <label class="" for="email">Email</label>
            <input type="email" name="email" id="email" class="form-control" placeholder="Email">
        </div>
    </div>

    <div class="row form-group">
        <div class="col-md-12">
            <label class="" for="treatment">Service You Want</label>
            <select name="treatment" id="treatment" class="form-control">
                <option value="">Hair Cut</option>
                <option value="">Hair Coloring</option>
                <option value="">Perms and Curls</option>
                <option value="">Hair Conditioning</option>
                <option value="">Manicure</option>
                <option value="">Pedicure</option>
                <option value="">Nails Extension</option>
                <option value="">Nail Design</option>
                <option value="">Waxing Eyebrows</option>
                <option value="">Waxing Hands/Legs</option>
                <option value="">Full Face Waxing</option>
                <option value="">Full Body/Body Parts Wax</option>
            </select>
        </div>
    </div>

    <div class="row form-group">
        <div class="col-md-12">
            <label class="" for="note">Notes</label>
            <textarea name="note" id="note" cols="30" rows="5" class="form-control" placeholder="Write your notes or questions here..."></textarea>
        </div>
    </div>

    <div class="row form-group">
        <div class="col-md-12">
            <center><input type="submit" value="Book Now" class="btn btn-primary btn-lg"></center>
        </div>
    </div>

</form>


-1

別のオプションは、事前にフォームグループの外にエラーコンテナーを配置することです。バリデーターは、必要に応じてそれを使用します。

<div class="form-group">
  <label class="control-label" for="new-task-due-date">When is the task due?</label>
  <div class="input-group date datepicker">
    <input type="text" id="new-task-due-date" class="required form-control date" name="dueDate" />
    <span class="input-group-addon">
      <span class="glyphicon glyphicon-calendar"></span>
    </span>                          
  </div>
  <label for="new-task-due-date" class="has-error control-label" style="display: none;"></label>
</div>
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.