1

タグ入力に対してlaravelの一意の検証を使用する必要がありますが、複数の値の問題に直面しています。1つの値を挿入すると一意のルールがうまく機能しますが、複数の値を追加すると機能しません。

これは私のコントローラーコードです

 public function createteacher()
 {
     $rules = array (
         'teacher-name'  => 'required|unique:teacher,name',
     );

     $msgs =array(
         'teacher-name.required' => 'please insert teacher name',  
         'unique' => 'teacher name already exist',
     );

     $validator = Validator::make(Input::all(),$rules,$msgs);

     if ($validator->fails())
     {
         return  Response::json(['success'=>false,'error'=>$validator->errors()->toArray() ]);
     }
     else
     {
         $c = count(explode(',', Input::get('teacher-name')));

         $teachers_ids = explode(',', Input::get('teacher-name'));

         //if Validated
         for ($i = 0 ; $i < $c ; $i++)
         {
             $new_teacher = Teacher::firstOrCreate(array('name'=>$teachers_ids[$i]));  
         }

         return Response::json(['success'=>true]); 
     }
 }

そして、これは私のビューコードです

<div class="col-md-6">
 <div class="box box-redorange">
  <div class="box-header">
   <h3 class="box-title" style="float:right"> Adding Teachers </h3>
  <i class="fa fa-spinner fa-spin fa-lg" style="display:none float:left;" id="teacher-adding-load"></i> &nbsp;
   </div>
  <div class="box-body">                                    

     {{Form::open(array('url'=>'management/createteacher','id'=>'teacher-form'))}}
   <div class="form-group">
    <label for="teacher-name[]">Teacher Name </label>
    <select multiple data-role="tagsinput" name="teacher-name[]"   id="teacher-name" class="form-control" autofocus="true">
           <option value="" ></option>
    </select>
      </div>                     
      </div> <!-- end box body-->
      <div class="box-footer">
      {{Form::submit('Add',array('style'=>'color:#fff;font-weight:bold; ','class' => 'btn btn-redorange btn-block btn-sm')) }}
       {{Form::close()}}
       </div> <!--end box footer -->
       </div> <!-- end box -->
       <div class="form-group help-block teahcer-form-msgs" style="display:none;">
             <small></small>
       </div> 
      </div> <!-- end col-m-6 -->

最後に私のajaxコード

 $(document).ready(function(){

 var msgs = $('.teahcer-form-msgs');

 $('#teacher-form').submit(function(e){
  e.preventDefault();
 var $teacher_loading = $('#teacher-adding-load').show();

   // form data
    var formData = new FormData ();

     formData.append('teacher-name' , $('#teacher-name').val());

 $.ajax({
 url:'/elaqsacenter/public/management/createteacher',
 method:'post',
 processData:false,
 contentType:false,
 cache:false,
 dataType: 'json',
 data:formData,
 complete:  function(){
      $teacher_loading.hide();
  },
   global: false,
   success:function(data){

   msgs.hide().find('small').empty();

   if (!data.success) {

    $.each(data.error,function(index,error){

        msgs.find('small').append('<p class="text-danger">'+'<span     

       class="glyphicon glyphicon-exclamation-sign" aria-hidden="true">

       </span>'+' '+error+'</p>');

      // disable submit button when throw Validation messages 
     $('input[type=submit]').prop("disabled", true);
       setTimeout(function() {
       $('input[type=submit]').prop("disabled", false);
      }, 4000);
  });
    msgs.slideDown();
    msgs.delay(3000).slideUp();

  }else{
 msgs.find('small').append('<p class="text-success">data Inserted</p>');
      msgs.slideDown();
      msgs.delay(3000).slideUp();
      setTimeout(function(){location.reload();},2000);  
   }

 },
  global: false,
  error:function(){},

   });

  });

});

私の主な質問は、タグ入力によって挿入された複数の値で一意のルールを使用する方法です

4

2 に答える 2

1

私は同じ問題を抱えていました。問題は、配列 [] を送信していることですteacher-name[]。それを踏まえて、送信後、次のように入力して、取得した配列全体を出力できるとしましょう。

$data=Input::all();
            echo '<p style="color: blue;">The array data submitted are :<br><strong>'.print_r(Input::all(),true).'</strong></p>';
            die();

実際に配列内の配列を取得していることに気付くでしょう。したがって、検証では、配列の配列ではなく、値の配列が必要です。

これを解決するには、foreach 関数を使用する必要があります。テスト目的で、教師の名前が 5 文字を超えないようにします。

    $data=Input::all();
                echo '<p style="color: blue;">The array data submitted are :<br><strong>'.print_r(Input::all(),true).'</strong></p>';
foreach ($data['teacher-name'] as $key => $value) {
$validacion=Validator::make(
                        array(
                            $key    =>  $value
                            ),
                        array(
                            $key    =>  'max:5'
                            ),
                        array(
                            'max'   => 'In Spanish i\'d say this field can\'t be greater than :max chars...'
                            )
                        );
                    if($validacion->fails()){
                        echo '<p style="color: red;">Validation has failed for <b>'.$value.'</b></p>';
                    }
}
            die();

したがって、解決策は、配列の配列を for に送信するときに foreach 関数を使用する必要があることですInput::all()

于 2015-05-19T15:48:22.887 に答える