php – Laravel-5如何使用id值和名称值填充数据库中的选择框

我想使用 illuminate\html创建一个类似下面的选择框:
<select>
    <option value="$item->id">$item->name</option>
    <option value="$item->id">$item->name</option>
</select>

在我的控制器中我尝试了这个:

public function create()
{
    $items = Items::all(['id','name']);

    return view('prices.create',compact('id','items'));
}

在我看来这个:

<div class="form-group">
    {!! Form::Label('item','Item:') !!}
    {!! Form::select('item_id',$items,null,['class' => 'form-control']) !!}
</div>

问题是,而不是$item-> name显示实体的所有信息.

Laravel为查询生成器提供了lists()函数

在您的情况下,您可以替换您的代码

$items = Items::all(['id','name']);

$items = Items::lists('name','id');

此外,您还可以将其与其他查询生成链接.

$items = Items::where('active',true)->orderBy('name')->lists('name','id');

来源:http://laravel.com/docs/5.0/queries#selects

Laravel 5.2的更新

非常感谢@jarry.正如您所提到的,Laravel 5.2的功能应该是

$items = Items::pluck('name','id');

要么

$items = Items::where('active',true)->orderBy('name')->pluck('name','id');

参考:https://laravel.com/docs/5.2/upgrade#upgrade-5.2.0 – 查看Deprecations列表

相关文章

laravel的dd函数不生效怎么办
看不懂laravel文档咋办
安装laravel框架出现command怎么办
Laravel开发API怎么使用事务
laravel怎么构建复杂查询条件
laravel如何实现防止被下载