我在Laravel项目上更新一行时遇到问题。表单完美地接收所有必要的信息,但是一旦我点击更新按钮,从表单解析的信息将返回null
我的编辑(表单)文件
@extends('layout')
@section('content')
<h1 class = "title">Edit Item</h1>
<form method="post" action="/listings/{{$listing->id}}">
@method('patch')
@csrf
<div>
<label class="label" for="name">Name of Item</label>
<div class="control">
<input required type="text" class="input" name="description" placeholder="Name of Item" value="{{$listing->title}}" >
</div>
</div>
<div>
{!! Form::select('lstatus',$lstatus,null) !!}
</div>
<div class="field">
<div class="control">
<button type="submit" class="button is-link">Update</button>
</div>
</div>
</form>
我的控制器:
public function edit(listing $listing, lstatus $lstatus)
{
$listing = $listing::find($listing->id);
$lstatus = lstatus::pluck('name','id');
return view('listings.edit', compact('listing','lstatus'));
}
public function update(listing $listing, lstatus $lstatus){
$listing = listing::find($listing->id);
$listing->listing_status_id = request('lstatus');
$listing->title=\request('description');
return back();
}
当我点击表单上的提交按钮时,没有任何反应。数据库中没有任何变化,我没有得到任何错误。
预期结果将是要更新的值。
在这种情况下,您可以使用update()
方法传递来自请求的所有输入并使用all()
方法作为参数,这将保存您在请求中自动发送的所有属性:
$listing = $listing::find($listing->id);
$listing->update($listing->all());
您还可以使用all方法将所有输入数据检索为数组:
update方法需要一组列和值对,表示应更新的列。
如果您不使用update()
方法,则应在进行任何更改后使用save()
方法:
$listing->listing_status_id = request('lstatus');
$listing->title=\request('description');
$listing->save();