我是yii的新人.更新记录时,我在下拉列表中获取所选值时遇到问题.
我有多个用户的电子邮件选择下拉列表.
添加它时工作正常,它允许我选择多个值,并可以在数据库中插入选中的值ids分隔.但问题是,当我想更新记录时,它只显示1个选定的记录.
这是我的代码:
在我的View文件中:
<div class="controls">
<?PHP echo $form->dropDownList($model, 'uid', $allUsers, array('class' => 'select2-me input-sel_large', 'multiple' => 'true', 'options' => array('' => array('selected' => true)))); ?>
<?PHP echo $form->error($model, 'uid') ?>
</div>
在我的Controller文件中:
$model = new User;
$allUsers = $model->getAllUsers();
在我的模型文件中:
public function getAllUsers() {
$arr = Yii::app()->db->createCommand()
->select('userEmail,pkUserID')
->from('tbl_user')
->queryAll();
$users = array();
if (is_array($arr)) {
foreach ($arr as $value) {
$users[$value['pkUserID']] = $value['userEmail'];
}
}
return $users;
}
有人可以帮忙吗?
解决方法:
例.希望这对你有所帮助.
class YourForm extends CFormModel
{
public $uid = array(); // selected pkUserID's
}
//in action
$yourForm = new YourForm();
$yourForm->uid = array(1,2,3); // for example selected users with pk 1,2,3
$this->render('your_view', array('yourForm'=>$yourForm));
//view
/** @var CActiveForm $form */
/** @var YourForm $yourForm */
echo $form->dropDownList(
$yourForm,
'uid',
CHtml::listData(User::model()->findAll(array('order' => 'userEmail ASC')), 'pkUserID', 'userEmail'),
array('empty' => '', 'multiple'=>true))
)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。