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

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

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

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

知道如何使用2个DB列first_name和last_name进行此操作吗?或者达到我最终目标的另一种方法

解决方法:

//在你的模特中

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

然后像这样抓住:

User::find(1)->profile->lists('full_name', 'id');

要么

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

我更喜欢第一个:)

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...