多个更新laravel与复选框(LARAVEL 5.2)

时间:2017-06-01 03:58:26

标签: php mysql laravel checkbox laravel-5.2

我想更新我选择的学生的班级数据。但我有限制,我选择的学生数据尚未正确更新。 编写代码时出错的是什么?

第一个我有一张学生桌:

{!! Form::open(['method' => 'POST', 'action' => ['SiswaController@pindah_kelas']]) !!}
  <div class="panel panel-primary">
    <div class="panel-heading" align="center">Daftar Data Siswa</div>
    <table id="dataSiswa" class="table table-striped">
      <thead>
        <tr>
          <th><input type="checkbox" name"select-all" id="select-all" />
          <th>NIPD</th>
          <th>NISN</th>
          <th>Nama Siswa</th>
          <th>Kelas</th>
          <th>Action</th>
        </tr>
      </thead>
      <tbody>
        <?php foreach($data_kelas as $siswa): ?>
        <tr>
          <td><input type="checkbox" name="checkbox" id="checkbox" value="{{ $siswa->id }}"></td>
          <td>{{ $siswa->nipd }}</td>
          <td>{{ $siswa->nisn }}</td>
          <td>{{ $siswa->nama_siswa }}</td>
          <td>{{ $siswa->kelas->nama_kelas }}</td>
          <td>
            <div class="box-button">
              {{ link_to('siswa/' . $siswa->id, '', ['title' => 'Detail', 'class' => 'btn btn-info btn-sm glyphicon glyphicon-list']) }}
            </div>
            <div class="box-button">
              {{ link_to('siswa/' . $siswa->id . '/edit', '', ['title' => 'Edit', 'class' => 'btn btn-warning btn-sm glyphicon glyphicon-edit']) }}
            </div>
            <div class="box-button">
              {!! Form::open(['method' => 'DELETE', 'action' => ['SiswaController@destroy', $siswa->id]]) !!}
                <button type="submit" class="btn btn-danger btn-sm" title="Hapus"><i class="glyphicon glyphicon-trash"></i></button>
              {!! Form::close() !!}
            </div>
          </td>
        </tr>
        <?php endforeach ?>
      </tbody>
    </table>
  </div>
  {!! Form::submit('Pindah Kelas', ['class' => 'btn btn-primary form-control']) !!}
  {!! Form::close() !!}

这是我的代码javascript:

<script type="text/javascript">
  $(document).ready(function(){
    $('#select-all').click(function(){
      if(this.checked) {
        $(':checkbox').each(function(){
          this.checked = true;
        });
      }
      else {
        $(':checkbox').each(function(){
          this.checked = false;
        });
      }
    });
  });
</script>

第二个是我的路线:

Route::get('siswa/pencarian_siswa', 'SiswaController@pencarian_siswa');
Route::resource('siswa', 'SiswaController');
Route::post('siswa', 'SiswaController@pindah_kelas');

最后我有控制器:

public function pindah_kelas(Siswa $siswa, Request $request)
{
  $input = $request->id;
  $siswa->update($input)->whereIn('id', $input(['id_kelas' => 3]));
  Session::flash('flash_message', 'Data Siswa Berhasil Diupdate.');
  return redirect('kelas');
}

我的问题是如何根据我选择的学生数据更新从当前班级到另一班级的学生转学? 如果你能帮助我解决这个问题,我将非常感激

1 个答案:

答案 0 :(得分:0)

首先你更新错了..它应该像

$siswa::whereIn('id', $request->checkbox)->update(['id_kelas' => $request->id]);

这会更新$request->id值复选框中选中的所有记录的id_kelas ..我不知道你的代码会在哪里获得,但我认为这样做了你的目标..

另一个错误是它只适用于你在循环中关闭表单的第一个复选框..代码将假定表单在那里结束..