2016-06-30 12 views
3

Ich habe handsontable implementiert, um Daten vom Benutzer zu erhalten. Das ist mein SkriptHandsontable gibt eine unerwartete Anzahl von Spalten

<script type="text/javascript"> 
    $(document).ready(function() { 
     $('#quiz_questions').handsontable({ 
      rowHeaders: true, 
      colHeaders: ['Question', 'Option 1', 'Option 2', 'Option 3', 'Option 4', 'Answer', 'Marks'], 
      columns: [ 
       { 
        type: 'text', 
        allowEmpty: false 
       }, 
       { 
        type: 'text', 
        allowEmpty: false 
       }, 
       { 
        type: 'text', 
        allowEmpty: false 
       }, 
       { 
        type: 'text', 
        allowEmpty: true 
       }, 
       { 
        type: 'text', 
        allowEmpty: true 
       }, 
       { 
        type: 'dropdown', 
        source: ['Option 1', 'Option 2', 'Option 3', 'Option 4'], 
        allowEmpty: false 
       }, 
       { 
        type: 'numeric', 
        allowEmpty: false 
       } 
      ], 
      stretchH: 'all', 
      minSpareRows: 0, 
      minSpareColumns: 0, 
      minRows : 25 
     }); 

     var hotInstance = $("#quiz_questions").handsontable('getInstance'); 

     $('#btnSave').click(function(e){ 
      e.preventDefault(); 
      $('#btnSave').prop("disabled", true); 
      //alert('btnclicked'); 

      var dynFrm = $('<form>', { 
       'action': '{{ action('[email protected]') }}', 
       'method': 'POST' 
      }).append($('<input>', { 
       'type': 'hidden', 
       'name': '_token', 
       'value': '{{ csrf_token() }}' 
      })).append($('<input>', { 
       'type': 'hidden', 
       'name': 'quiz_id', 
       'value': '{{ $quiz->quiz_id }}' 
      })).append($('<input>', { 
       'type': 'hidden', 
       'name': 'data', 
       'value': JSON.stringify(hotInstance.getData()) 
      })); 
      dynFrm.appendTo(document.body).submit(); 
     }); 

    }); 

</script> 

Die storeBulk() Funktion von QuizQuestionController die Daten verarbeitet.

public function storeBulk() 
    { 
     // get the quiz model 
     $quiz = Quiz::findOrFail(Input::get('quiz_id')); 

     // get the data 
     $data = Input::get('data'); 
     $jData = json_decode($data); 

     //process the recevied data 
     foreach($jData as $row) { 
      $quizQuestion = new QuizQuestion(); 

      $quizQuestion->quiz_id = $quiz->quiz_id; 
      $quizQuestion->question_no = $cnt; 
      $quizQuestion->question_text = trim($row[0]) ? : null; 
      $quizQuestion->options = $this->processOptions([ 
             trim($row[1]), 
             trim($row[2]), 
             trim($row[3]), 
             trim($row[4]) 
             ]); 
      $quizQuestion->answer = $this->processAnswer($row[5]); 
      $quizQuestion->marks = trim($row[6]) ? : null; 

      ... 
    } 

Das Problem ist jetzt, für die Zeilen, die in dem handsontable leer gelassen werden, während die Daten füllen, ich data für die Zeilen als [null,null,null,null,null,null,null] bekommen sollte. Aber das ist nicht der Fall. Für einige Zeilen bekomme ich [null,null,null,null,null] (nur 5 Werte). So bekomme ich einen ErrorException Spruch Undefined offset: 5.

Ich habe bemerkt, dass dies nur für die ersten 5 Zeilen passiert. Was könnte das Problem sein?

Antwort

2

Das Problem festgestellt.

Ich habe bemerkt, dass dies nur für die ersten 5 Zeilen passiert. Was könnte das Problem sein?

Es gibt eine startRows Eigenschaft handsontable die standardmäßig 5. Daher das Problem mit den ersten 5 Zeilen. Ich habe die Eigenschaft explizit auf

startRows: 0, 

und modifiziert auch die storeBulk() Funktion Fehler zu ignorieren.

$quizQuestion->question_text = trim(@$row[0]) ? : null; 
$quizQuestion->options = $this->processOptions([ 
            trim(@$row[2]), 
            trim(@$row[3]), 
            trim(@$row[4]), 
            trim(@$row[5]) 
           ]); 
$quizQuestion->answer = $this->processAnswer(@$row[6]); 
$quizQuestion->marks = trim(@$row[7]) ? : null; 

Jetzt funktioniert alles korrekt.

0

Haben Sie versucht, hotInstance.getSourceData() anstelle von hotInstance.getData() zu verwenden? Die Funktionalität für diese Methode hat sich mit der neuesten Version geändert, die ähnliche Probleme für andere Personen verursacht hat.