我正在研究Yii2。我正在使用这样的自定义数组创建多个选择下拉列表。
在控制器文件中:
$all_groups = Groups::find()->where(['=','group_created_by',$id])->orwhere(new Expression('FIND_IN_SET(:id_to_find, group_managers)'))->addParams([':id_to_find' => $id])->all(); // fetch all values
$selected_groups = Groups::find()->where(['=','group_users',$updateId])->orwhere(new Expression('FIND_IN_SET(:id_to_find, group_users)'))->addParams([':id_to_find' => $updateId])->all(); // getting selected values
$all_groups_array = [];
foreach ($all_groups as $group) {
$all_groups_array[$group->id] = ucfirst($group->group_name);
}
在视图上渲染数据:
return $this->render('mngr_userupdate', [
'model' => $model,
'all_groups_array'=>$all_groups_array,
'case'=>$case,
'email_error' => 'false',
'applied_email' => '' ,
]);
所以它正在创建这样的数组:
Array
(
[11] => Mngr1 group
[14] => Mngr 11 Group
)
在vies文件中:
<?= $form->field($model, 'group_user[]')->dropDownList($all_groups_array,['multiple' => 'multiple']) ?>
它在创建表单上正常工作以进行数据插入。但是如何创建数组,我可以在更新表格上显示选定的值。
修改
我刚刚发现,如果我像
一样使用它<?= $form->field($model, 'group_user[]')->dropDownList($all_groups_array,['multiple' => 'multiple', 'options'=>['14'=>["Selected"=>true],'11' => ["Selected"=>true]]]); ?>
然后它将启动所选的显示值。即我必须创建像
这样的数组[
'14'=>["Selected"=>true],
'11' => ["Selected"=>true]
]
为此,我使用如下循环:
foreach ($selected_groups as $key => $value) {
$sel_groups_array[$value] = '' // what should be there or else
}
如何使用循环创建此数组?
答案 0 :(得分:4)
我已经创建了我的问题的解决方案,如果有人遇到这样的问题,那么他可以使用如下的循环:
foreach ($selected_groups as $group) {
$sel_groups_array[$group->id] = array("selected"=>true);
}
并且在视图文件中,您可以使用数组显示选定的多个值,如下所示:
<?= $form->field($model, 'group_user[]')->dropDownList($all_groups_array,['multiple' => 'multiple','options' => $sel_groups_array]); ?>
因为在更新表单上显示多个选定值的结构,它应该如下所示:
$form->field($model, 'group_user[]')->dropDownList($all_groups_array,['multiple' => 'multiple', 'options'=>['14'=>["Selected"=>true],'11' => ["Selected"=>true]]]);
// here 14 and 11 I am using as example