如何让Yii从已知用户生成下拉列表?

Mar*_*tin 0 php activerecord non-relational-database yii

我刚刚开始学习使用yii,并且已经设法做了一些基本的东西.

假设我有两个简单的表:"用户"和"项目",其中关系是1到多(一个用户可以有很多项目)

我使用GII生成了CRUD,但是在"创建/编辑用户页面"中,这不提供下拉列表,而只提供我需要输入用户ID的文本字段.

在编辑项目时,我想有一个下拉列表,我可以在其中选择一个用户(因此该元素应该显示一个用户名列表).

我假设GII无法为此生成控制器和查看代码

这样做的最佳做法是什么?

我已按照http://www.yiiframework.com/doc/guide/1.1/en/database.arr中的说明声明了这些关系

public function relations()
{
   return array(
        'projects_rel'=>array(self::BELONGS_TO, 'Users', 'user_id'),
    );
}
Run Code Online (Sandbox Code Playgroud)

public function relations()
{
    return array(
        'users_rel'=>array(self::HAS_MANY, 'Projects', 'project_id'),
    );
}
Run Code Online (Sandbox Code Playgroud)

Sur*_*esh 6

找到生成用户列表的示例代码

<?php
    $form = $this->beginWidget('CActiveForm', array(
                'id' => 'project-form',
                'enableAjaxValidation' => true,
            ));
Run Code Online (Sandbox Code Playgroud)

?>

<?php echo $form->dropDownList($model, 'user_id',
                CHtml::listData(Projects::model()->with('projects_rel')->findAll(), 'id', 'username'),
                array('style'=>'width:150px;')
                ); ?>
Run Code Online (Sandbox Code Playgroud)