我正在尝试将从数据库中提取的选定值加载到Select2中。 Id值保存在JSON字段中,该字段包含id值或我管理为'All'的字段'*'。
这是我的控制器方法:
$data['field_id'] = array();
$field_id_array = json_decode(User::find($id) -> field_id);
if( $field_id_array !== null ) {
$field_array = Campo::whereIn('id',$field_id_array)->pluck('field_name','id');
if( in_array( '*' , $field_id_array ) ) {
$field_array -> prepend( 'All' , '*' );
}
$data['field_id'] = $field_array;
}
return view('create', $data);
这是我的观点,我正在使用Blade:
<select id="field_id" name="field_id[]" multiple>
@if(!empty($field_id))
@foreach($field_id as $f)
<option value = "{!! $f->id !!}" selected >{!! $f->field_name !!}
</option>
@endforeach
@endif
</select>
显示的错误是:
尝试获取非对象的属性
如果我在视图循环中仅使用{!! $c !!}
,我没有错,但它只显示字段field_name
。
我正在使用带有ajax搜索的Select2,但我没有发布代码,因为我认为控制器方法中的错误是99.9%。
任何人都有解决问题的想法吗?
答案 0 :(得分:2)
Collection::pluck方法在你的情况下返回一个关联数组而不是一个对象数组,这就是为什么你的循环应该是这样的:
@foreach($field_id as $id => $field_name)
<option value = "{{ $id }}" selected >{{ $field_name }}</option>
@endforeach
答案 1 :(得分:0)
如果您使用blade
,并且使用pluck
创建仅2种类型的数组。您可以使用以下语法,将$ field_array传递给视图:
{{Form::select('field_id[]',
$field_array,
'', array('class'=>'your-class',
'id' => 'field_id',
'multiple'))}}