我想在显示的同一页面上更改用户数据。 基本上,我想选择已验证或已拒绝,单击提交按钮,页面随更改而刷新。 所以我有这段代码:
<table class="table table-striped">
<thead>
<tr>
<th scope="col">#</th>
<th scope="col">Name</th>
<th scope="col">Receipt</th>
<th scope="col">Status</th>
<th scope="col"></th>
</tr>
</thead>
<tbody>
@foreach($users as $user)
<tr>
<form method='POST' action="{{ action('PaymentController@update' , $user->id )}}"
enctype="multipart/form-data">
@csrf
@method('PUT')
<th scope="row">{{$user->id}}</th>
<td>{{$user->name}}</td>
<td>
<a href="/{{$user->receipt}}">{{$user->receipt}}</a>
</td>
@if( $user->payment_status != NULL )
<td>
PAYMENT VERIFIED
</td>
@else
<td>
<div class="form-group">
<select multiple class="form-control-sm" id="exampleFormControlSelect2" name="nsap_reg"
required="">
<option value="verified">Verified</option>
<option value="NULL">Rejected</option>
</select>
</div>
</td>
@endif
<td>
<input type="submit" value="SUBMIT">
</td>
</form>
</tr>
@endforeach
</tbody>
</table>
控制器:
public function update(Request $request, $id)
{
$request->validate([
'nsap_reg' => 'required',
]);
$payment_status = \App\User::find($id);
['nsap_reg' => $request->nsap_reg];
$payment_status->save();
return redirect('user-status');
}
我的问题是,当我单击“提交”时,页面什么都没有刷新。 任何帮助将不胜感激。
答案 0 :(得分:2)
您只需要将nsap_reg
的值设置为用户对象并保存。
$payment_status = \App\User::find($id);
$payment_status->nsap_reg = $request->nsap_reg;
$payment_status->save();
答案 1 :(得分:1)
正如我所看到的,您创建了具有多个选择的选择列表,当您将数据保存到数据库时,您将发送数组数据进行保存。 但是您必须首先将其转换为json,然后设置为save。
下面是保存多选nsap_reg
的示例。
<?php
public function update(Request $request, $id)
{
$request->validate([
'nsap_reg.*' => 'required',
]);
$payment_status = \App\User::find($id);
$payment_status->nsap_reg = json_encode($request->input('nsap_reg'));
$payment_status->save();
return redirect('user-status');
}
但是,如果您使用的是单选,则从选择列表中删除multiple
属性,然后使用此代码
<?php
public function update(Request $request, $id)
{
$request->validate([
'nsap_reg' => 'required',
]);
$payment_status = \App\User::find($id);
$payment_status->nsap_reg = $request->input('nsap_reg');
$payment_status->save();
return redirect('user-status');
}