2016-09-05 7 views
4

ちょっとした変更を加えて、私が必要とするコードスニペットを見つけました。 The sample code is hereにアクセスし、hereにアクセスできるサンプルフォームを作成しようとしました。 私が必要とする唯一の調整は、フォームがロードされた後に必須フィールドにアスタリスクを表示することです。しかし今のところ、エラースタイルが表示されます(ページが開くときには望ましくありません)。どのようにフォームを変更できますか?検証のためにブートストラップのフォームスタイルを変更してください

スクリプト

$(document).ready(function() { 
    $('.input-group input[required], .input-group textarea[required], .input-group select[required]').on('keyup change', function() { 
     var $form = $(this).closest('form'), 
      $group = $(this).closest('.input-group'), 
      $addon = $group.find('.input-group-addon'), 
      $icon = $addon.find('span'), 
      state = false; 

     if (!$group.data('validate')) { 
      state = $(this).val() ? true : false; 
     } else if ($group.data('validate') == "email") { 
      state = /^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/.test($(this).val()) 
     } else if ($group.data('validate') == 'phone') { 
      state = /^[(]{0,1}[0-9]{3}[)]{0,1}[-\s\.]{0,1}[0-9]{3}[-\s\.]{0,1}[0-9]{4}$/.test($(this).val()) 
     } else if ($group.data('validate') == "length") { 
      state = $(this).val().length >= $group.data('length') ? true : false; 
     } else if ($group.data('validate') == "number") { 
      state = !isNaN(parseFloat($(this).val())) && isFinite($(this).val()); 
     } 

     if (state) { 
      $addon.removeClass('danger'); 
      $addon.addClass('success'); 
      $icon.attr('class', 'glyphicon glyphicon-ok'); 
     } else { 
      $addon.removeClass('success'); 
      $addon.addClass('danger'); 
      $icon.attr('class', 'glyphicon glyphicon-remove'); 
     } 

     if ($form.find('.input-group-addon.danger').length == 0) { 
      $form.find('[type="submit"]').prop('disabled', false); 
     } else { 
      $form.find('[type="submit"]').prop('disabled', true); 
     } 
    }); 

    $('.input-group input[required], .input-group textarea[required], .input-group select[required]').trigger('change'); 
}); 

HTMLは

<div class="container"> 
    <div class="row"> 
     <h2>Input Validation + Colorful Input Groups</h2> 
    </div> 
    <div class="row"> 
     <div class="col-sm-offset-4 col-sm-4"> 
     <form method="post"> 
      <div class="form-group"> 
       <label for="validate-text">Validate Text</label> 
       <div class="input-group"> 
        <input type="text" class="form-control" name="validate-text" id="validate-text" placeholder="Validate Text" required> 
        <span class="input-group-addon danger"><span class="glyphicon glyphicon-remove"></span></span> 
       </div> 
      </div> 
      <div class="form-group"> 
       <label for="validate-optional">Optional</label> 
       <div class="input-group"> 
        <input type="text" class="form-control" name="validate-optional" id="validate-optional" placeholder="Optional"> 
        <span class="input-group-addon info"><span class="glyphicon glyphicon-asterisk"></span></span> 
       </div> 
      </div> 
      <div class="form-group"> 
       <label for="validate-optional">Already Validated!</label> 
       <div class="input-group"> 
        <input type="text" class="form-control" name="validate-text" id="validate-text" placeholder="Validate Text" value="Validated!" required> 
        <span class="input-group-addon danger"><span class="glyphicon glyphicon-remove"></span></span> 
       </div> 
      </div> 
      <div class="form-group"> 
       <label for="validate-email">Validate Email</label> 
       <div class="input-group" data-validate="email"> 
        <input type="text" class="form-control" name="validate-email" id="validate-email" placeholder="Validate Email" required> 
        <span class="input-group-addon danger"><span class="glyphicon glyphicon-remove"></span></span> 
       </div> 
      </div> 
      <div class="form-group"> 
       <label for="validate-phone">Validate Phone</label> 
       <div class="input-group" data-validate="phone"> 
        <input type="text" class="form-control" name="validate-phone" id="validate-phone" placeholder="(814) 555-1234" required> 
        <span class="input-group-addon danger"><span class="glyphicon glyphicon-remove"></span></span> 
       </div> 
      </div> 
      <div class="form-group"> 
       <label for="validate-length">Minimum Length</label> 
       <div class="input-group" data-validate="length" data-length="5"> 
        <textarea type="text" class="form-control" name="validate-length" id="validate-length" placeholder="Validate Length" required></textarea> 
        <span class="input-group-addon danger"><span class="glyphicon glyphicon-remove"></span></span> 
       </div> 
      </div> 
      <div class="form-group"> 
       <label for="validate-select">Validate Select</label> 
       <div class="input-group"> 
        <select class="form-control" name="validate-select" id="validate-select" placeholder="Validate Select" required> 
        <option value="">Select an item</option> 
        <option value="item_1">Item 1</option> 
        <option value="item_2">Item 2</option> 
        <option value="item_3">Item 3</option> 
        </select> 
        <span class="input-group-addon danger"><span class="glyphicon glyphicon-remove"></span></span> 
       </div> 
      </div> 
      <div class="form-group"> 
       <label for="validate-number">Validate Number</label> 
       <div class="input-group" data-validate="number"> 
        <input type="text" class="form-control" name="validate-number" id="validate-number" placeholder="Validate Number" required> 
        <span class="input-group-addon danger"><span class="glyphicon glyphicon-remove"></span></span> 
       </div> 
      </div> 
      <button type="submit" class="btn btn-primary col-xs-12" disabled>Submit</button> 
     </form> 
     </div> 
    </div> 
</div> 
+0

アスタリスクを赤で十字ではなく青で表示しますか? – Zeeshan

答えて

1

あなたのスクリプトからの行の次のコメントをする必要があります。

$('.input-group input[required], .input-group textarea[required], .input-group select[required]').trigger('change'); 

これはdocument.readyの最後の行です。これは、ページのロード時に変更イベントをトリガし、アスタリスクをクロスに変更する行です。ちょうどこの行をコメントし、あなたは行くのが良いです。

EDIT 代わりinfoクラスのdangerクラスを追加します。デフォルトではアスタリスクが赤で表示され、検証時には緑色の背景にチェックマークが付きます。私はあなたのアスタリスクフォームグループを以下のように変更します。 オプション

NOTE 元に戻すスクリプトは、私が前に提案された変更します。

+0

ありがとうございました。別の質問があります。現在、アスタリスクは青色の背景にあり、正しい情報を入力すると青色の背景にチェックマークが再び表示されます。正しい情報を受け取った後で、チェックマークの背景を緑色に変更するにはどうすればよいですか? – Amir

+0

私はあなたの要件に応じて私の答えを更新しました。これがあなたが必要とするものなら、これを受け入れられた回答としてマークしてください。 – Zeeshan

+0

もう一度ありがとう、それは素晴らしい動作します! もう1つ質問があります。私は新しいユーザーにサインアップするためにこのフォームを使用するつもりです。したがって、このユーザー名が既に取得されていないことを確認するために、いくつかのフィールドでサーバーとの二重チェックが必要です。これを行うには、私はAjaxの使用を考えています 教えてください。上記のコードでサーバーとの値をテストするにはどうしたらいいですか?繰り返しのユーザー名の場合は、赤い背景に十字を表示したいと思います(このユーザー名が既に使用中であることを示すテキストかもしれません)。 – Amir

関連する問題