将数据更新到数据透视表

时间:2018-07-09 12:27:47

标签: php laravel

我有很多现实,现在我想知道我该如何使用用户发送给app的表单更新表。这是我的代码 路线:

Route::get('admin/client/assign','ClientController@assignsellman');

这是我的控制器

public function assignsellman(Client $client){
    $user = User::all();
    $client_list = Client::all();
    $client = Client::with('sellmanlist')->firstOrFail();
    $sellman = $request->input('sellman');
    $client_name = $request->input('client');
    $client->sellmanlist()->attach($sellman);
    $client->sellmanlist()->attach($client_name);
    $client->save();
    return view('admin.client.assign',compact('client_list','user'));

}

最后确定视图:

 <form action="/admin/client/" method="get">
                <input type="hidden" name="_method" value="PUT">
                {{ csrf_field() }}
                <div class="row">
                    <div class="col-xs-4">
                        <div class="form-group">
                            <label for="client">مشتری</label>
                            <select class="" tabindex="-1" aria-hidden="true"
                                    name="client">
                                @foreach($client_list as $client_lists)
                                    <option value="{{$client_lists->id}}">{{$client_lists->title}}</option>
                                @endforeach
                            </select>
                        </div>
                    </div>
                    <div class="col-xs-4 text-center">
                        <i class="icon-arrow-left7 mr-3 icon-3x" style="font-size: 130px"></i>
                        <h4>ارجاع به</h4>
                    </div>
                    <div class="col-xs-4">
                        <div class="form-group">


                            <div class="form-group">
                                <label for="sellman">کارشناس فروش</label>
                                <select class="" tabindex="-1"
                                        aria-hidden="true" name="sellman">
                                    @foreach($user as $users)
                                        <option value="{{$users->id}}">{{$users->name}}</option>
                                    @endforeach
                                </select>
                            </div>

                        </div>
                    </div>

                </div>
                @if ($errors->any())
                    <div class="alert alert-danger">
                        <ul>
                            @foreach ($errors->all() as $error)
                                <li>{{ $error }}</li>
                            @endforeach
                        </ul>
                    </div>
                @endif
                <button type="submit" class="btn btn-primary">تایید</button>
            </form>

当我提交此表单时,它会重定向到这样的网址 ?_method = PUT&_token = mvf0i2FaxSBhDdJroqD6L1901QdvcR4b3tmgwekw&client = 3&sellman = 3 而且数据库什么也没发生。知道我的错是什么?

1 个答案:

答案 0 :(得分:1)

在您的情况下,您需要2条路线,第一条路线用于退货表格,第二条路线用于保存表格中的数据。 您的路线:

Route::get('admin/client/assign','ClientController@assignsellman');
Route::post('admin/client/assign','ClientController@assignsellmanSave');

控制器:

public function assignsellman(Client $client)
{
   $user = User::all();
   $client_list = Client::all();

   return view('admin.client.assign',compact('client_list','user'));
}

public function assignsellmanSave(Client $client)
{
   $user = User::all();
   $client_list = Client::all();
   $client = Client::with('sellmanlist')->firstOrFail();
   $sellman = $request->input('sellman');
   $client->sellmanlist()->attach($sellman);
   $client->save();
   return view('admin.client.assign',compact('client_list','user'));
}

查看:

<form action="/admin/client/assign" method="post">
            {{ csrf_field() }}
            <div class="row">
                <div class="col-xs-4">
                    <div class="form-group">
                        <label for="client">مشتری</label>
                        <select class="" tabindex="-1" aria-hidden="true"
                                name="client">
                            @foreach($client_list as $client_lists)
                                <option value="{{$client_lists->id}}">{{$client_lists->title}}</option>
                            @endforeach
                        </select>
                    </div>
                </div>
                <div class="col-xs-4 text-center">
                    <i class="icon-arrow-left7 mr-3 icon-3x" style="font-size: 130px"></i>
                    <h4>ارجاع به</h4>
                </div>
                <div class="col-xs-4">
                    <div class="form-group">


                        <div class="form-group">
                            <label for="sellman">کارشناس فروش</label>
                            <select class="" tabindex="-1"
                                    aria-hidden="true" name="sellman">
                                @foreach($user as $users)
                                    <option value="{{$users->id}}">{{$users->name}}</option>
                                @endforeach
                            </select>
                        </div>

                    </div>
                </div>

            </div>
            @if ($errors->any())
                <div class="alert alert-danger">
                    <ul>
                        @foreach ($errors->all() as $error)
                            <li>{{ $error }}</li>
                        @endforeach
                    </ul>
                </div>
            @endif
            <button type="submit" class="btn btn-primary">تایید</button>
        </form>