php - 带复选框的多次更新 Laravel (LARAVEL 5.2)

标签 php mysql laravel checkbox laravel-5

我想更新我选择的学生的类(class)数据。但我有一个限制,即我选择的学生数据尚未成功正确更新。 我的代码编写有什么错误?

第一个我有一个学生表:

{!! 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');

我最后一个 Controller :

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');
}

我的问题是如何根据我选择的学生数据更新从当前类(class)转入另一个类(class)的学生? 如果您能帮助我解决这个问题,我将非常感激

最佳答案

首先你的更新是错误的..它应该是这样的

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

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

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

关于php - 带复选框的多次更新 Laravel (LARAVEL 5.2),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44298307/

相关文章:

Laravel 4 Workbench undefined offset

php - 如何为视频添加动态链接?

php - 在php中循环执行mysql查询,参数存储在来自android的arrayList中

php - 如何从 MYSQL 数据库中的最后 10 条记录中获取最小的 ID?

mysql - 定位字符串中第 n 次出现*之后*的所有内容

php - 在 PHP 中更改父属性的值

php - 使用 php 变量作为 sql 字段 laravel Eloquent ORM

php - Zend 框架 : How to unset the one stylesheet from the HeadLink helper

php - 当转到登录页面时,如果已经登录,则重定向到索引

php - 无法实例化\Aws\Ec2\Ec2Client