Laravel 5 更新数据库中现有的内容


Laravel 5 Update existing in database

我正在尝试使用引导模式中的表单更新表中的现有行。但是当我尝试它时没有任何变化。我有一个带有汽车列表的 html 表,每行都有一个"更改状态"按钮,该按钮使用id="myModal_{{ $car->id }}"打开引导模式,其中包含其中的表单以编辑正在维修的汽车的状态。

这是我的模态:

<!-- Modal -->
<div class="modal fade" id="myModal_{{ $car->id }}" tabindex="-1" role="dialog" aria-labelledby="myModalLabel">
  <div class="modal-dialog" role="document">
    <div class="modal-content">
      <div class="modal-header">
        <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
        <h4 class="modal-title" id="myModalLabel">Breyta stöðu bíls</h4>
      </div>
      <div class="modal-body">
        <div class="form-group">
          <h3>Breyta stöðu fyrir {{ $car->LicencePlate }}</h3>
        </div>
            {!! Form::open(['url' => 'create']) !!}
              <div class="form-group">
                {!! Form::label('Status', 'Status: ') !!}
                {!! Form::select('Status', [
                                  null => ' -- Veldu Stöðu bíls -- ',
                                  'Í Biðröð' => 'Í Biðröð',
                                  'Í Viðgerð' => 'Í Viðgerð',
                                  'Tilbúinn' => 'Tilbúinn'
                                  ], null, ['class' => 'form-control']) !!}
              </div>
              <div class="form-group">
              </div>
      </div>
      <div class="modal-footer">
        <button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
        {!! Form::submit('Skrá stöðu', ['class' => 'btn btn-primary']) !!}
      </div>
      {!! Form::close() !!}
    </div>
  </div>
</div>

车载控制器中的更新方法:

public function CarEdit($id, Requests'CreateCarsRequest $request)
{
  $edit = Car::update($request->all());
  return redirect::back();
}

我的方法路线:

Route::post('/dashboard', 'CarController@CarEdit');

你应该这样做:

['action' => 'CarController@CarEdit']

此外,您使用的是 mass assignment ,因此您必须在Car模型中填充$fillable数组才能使其正常工作:https://laravel.com/docs/5.1/eloquent#mass-assignment

在同事的帮助下,我能够解决这个问题。我所做的是创建一个名为UpdateCarRequest的新请求,其中LicencePlate字段不是唯一的。并像这样编辑了我的方法:

public function CarEdit(Requests'UpdateCarRequest $request)
{
  $edit = Car::where('LicencePlate', '=', $request->LicencePlate)->first();
  $edit->update($request->all());
  return redirect('/dashboard');
}

我还在表单中添加了一个值为 $car->LicencePlate 的隐藏字段。