Laravel:编辑显示在同一页面上的数据

时间:2018-10-10 11:13:39

标签: laravel laravel-5 crud

我想在显示的同一页面上更改用户数据。 基本上,我想选择已验证或已拒绝,单击提交按钮,页面随更改而刷新。 所以我有这段代码:

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

我的问题是,当我单击“提交”时,页面什么都没有刷新。 任何帮助将不胜感激。

2 个答案:

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