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

I can't get data when i am editing in laravel 5.1

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

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

然后在 select 中的视图中,您应该将 $users 和 $address_users 的数组相交以获得 selected 选项。

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

避免

isset($address_users) ? $address_users : null

您可以在您的创建方法中定义空 address_users 数组,然后像这样

$address_users