Laravel 4使用2个数据库列填充下拉列表?

Jas*_*vis 4 php laravel laravel-4

echo Form::select(
    'campaign_user_id',
    User::find(1)->profile->lists('first_name', 'id'),
    Input::get('campaign_user_id', $campaign->user_id),
    array(
      "placeholder" => "US",
      'class' => 'form-control',
      'disabled' => 'disabled'
    )
)
Run Code Online (Sandbox Code Playgroud)

上面的代码用于构建下拉列表选择列表.它从数据库中获取用户列表.在第3行你可以看到User::find(1)->profile->lists('first_name', 'id')

它正在获取first_name列,我需要以某种方式获取名字和姓氏列,并将它们组合在此列表中.因此列表值仍然是用户ID,并显示全名.

知道如何使用2个DB列first_namelast_name?或者达到我最终目标的另一种方法?

Luc*_*oni 6

//在你的模特中

class User extends Eloquent
{
    public function getFullNameAttribute()
    {
        return $this->attributes['first_name'] . ' ' . $this->attributes['last_name'];
    }
}
Run Code Online (Sandbox Code Playgroud)

然后像这样抓住:

User::find(1)->profile->lists('full_name', 'id');
Run Code Online (Sandbox Code Playgroud)

要么

User::find(1)->profile->select(DB::raw('concat (first_name," ",last_name) as full_name,id'))->lists('full_name', 'id');
Run Code Online (Sandbox Code Playgroud)

我更喜欢第一个:)