当我在laravel 5.1中编辑时,我无法获取数据

时间:2016-01-09 16:17:40

标签: laravel model eloquent laravel-5.1 laravel-blade

i have address Book table and user table i am assigning 
我创建的地址簿中的很多用户一切都很好(好的)  但是当我在我的表单中编辑每个数据而没有分配用户时。 如何让用户以编辑形式?这是我的地址簿控制器  

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Http\Requests\AddressRequest;
use App\Http\Requests;
use App\Models\Address;
use App\Models\User;
use App\Http\Controllers\Controller;`enter code here`
use Illuminate\Pagination\Paginator;
use Auth;
use DB;
use Session;

class AddressesController extends Controller
{
    /**
     * Display a listing of the resource.
     *
     * @return Response
     */
    public function index(Request $request)
    {
        Session::forget('searchaddress');

       $addresses = Address::orderby('company_name');

        $company_name = $request->input('company_name');

        if(!empty($company_name)) {

              //$addresses->where('company_name','LIKE','%'.$company_name.'%');

             $addresses->where('company_name','LIKE','%'.$company_name.'%');
            Session::set('searchaddress', $company_name);
        }
        $addresses = $addresses->paginate(5);


        return view('address.index',compact('addresses'));
    }

    /**
     * Show the form for creating a new resource.
     *
     * @return Response
     */
    public function create()
    {

        $users = User::lists('first_name','id');

        return view('address.create',compact('users'));
    }

    /**
     * Store a newly created resource in storage.
     *
     * @return Response
     */
    public function store(AddressRequest $request)
    {

        $address = Address::create($request->all());
        $firstname = Auth::user()->first_name;
        $lastname = Auth::user()->last_name;
        $address->created_by =$firstname." ".$lastname;

        $address->users()->attach($request->input('user_list'));
        $address->save();
        return redirect('/addresses');
    }

    /**
     * Display the specified resource.
     *
     * @param  int  $id
     * @return Response
     */
    public function show($id)
    {
        $address = Address::find($id);
        return view('address.show',compact('address'));
    }

    /**
     * Show the form for editing the specified resource.
     *
     * @param  int  $id
     * @return Response
     */
    public function edit($id)
    {   $users = User::lists('first_name','id');
        $address = Address::findorFail($id);

        return view('address.edit',compact('address','users'));
    }

    /**
     * Update the specified resource in storage.
     *
     * @param  int  $id
     * @return Response
     */
    public function update( AddressRequest $request ,$id)
    {

        $address = Address::findOrFail($id);
        $address->update($request->all());
        $address->users()->sync($request->input('user_list'));
        return redirect('/addresses');

    }

    /**
     * Remove the specified resource from storage.
     *
     * @param  int  $id
     * @return Response
     */
    public function destroy($id)
    {
        $address = Address::find($id);
        $address->delete();
        return redirect('/addresses');
    }


}
 and that is my AddressBook Model 
<?php

namespace App\Models;

use Illuminate\Database\Eloquent\Model;

class Address extends Model
{
    protected $fillable = [
    'created_by',
    'company_name',
     'phone', 
     'email', 'address','comment'
    ];
    public function users()
    {
        return $this->belongsToMany('App\Models\User')->withTimestamps();
    }
    public function getUserListAttribute()
    {
        return $this->users->lists('id');
    }
}

 [![enter image description here][1]][1]


  [1]: http://i.stack.imgur.com/D4jXQ.png

1 个答案:

答案 0 :(得分:0)

你有belongsToMany关系,所以在你的编辑动作中你也应该得到像这样的当前地址用户

public function edit($id)
    {   $users = User::lists('first_name','id');
        $address = Address::findorFail($id);
        $address_users = $address->users->lists('id')->toArray();

        return view('address.edit',compact('address','users', 'address_users'));
    }

然后在你的视图中选择你应该与$ users和$ address_users的数组相交以获得所选的选项。

{!! Form::select('user_list[], $users, isset($address_users) ? $address_users : null, ['id' => 'users_list', 'class' => 'form-control', 'multiple']) !!}

避免

isset($address_users) ? $address_users : null

您可以在create方法中定义空的address_users数组,并按照这样做

$address_users