我会尽可能清楚地描述问题。
我有activeDataProvider:
$dataProvider=new CActiveDataProvider('Menu', array(
'criteria'=>array(
'with' => array('roles'),
),
));
然后我使用带有复选框的CGridView:
$this->widget('zii.widgets.grid.CGridView', array(
'id'=>'menu-grid',
'selectableRows' => 2,
'dataProvider'=>$dataProvider,
'columns'=>array(
'id',
'title',
array(
'class' => 'SCheckboxColumn',
'header' => 'View',
'name' => 'Roles[Actions][can_view]',
'id' => 'roles_action_can_view',
'value' => '$data->id',
'checkBoxHtmlOptions' =>
array('checked' => $data->roles->can_view),
),
),
));
然后在菜单模型关系中:
return array(
'roles' => array(self::HAS_MANY, 'Rolesmenus', 'menu_id'),
);
和Rolesmenus Model关系:
return array(
'menu' => array(self::BELONGS_TO, 'Menu', 'menu_id'),
);
所以,我无法访问$ data-> roles-> can_view变量,当我var_dump所有$ data对象时,我可以在_attributtes私有数组中看到这些属性,但我不能通过CGridView访问它们。
任何想法??
答案 0 :(得分:0)
array('checked'=> $ data-> roles-> can_view,),
需要 数组('checked'=>'$ data-> roles-> can_view',),
答案 1 :(得分:0)
当您的关系是HAS_MANY时,调用该关系将返回该ActiveRecord的数组。 CGridView不会显示数组,所以我过去所做的就是在模型中编写一个函数,该函数包含获取数组中所有值并从中创建字符串的关系。例如,菜单模型中的示例执行类似这样的操作
public function rolesToString()
{
$roles = $this->roles;
if($roles) {
$string = '';
foreach($roles as $role) {
$string .= $role->can_view . ', ';
}
return substr($string,0,strlen($string)-1); // substr to remove trailing comma
}
return null;
}
然后该列的CGridView的'value'属性应该如下所示
'value'=>'$data->rolesToString()'
有关于使用HAS_MANY的更多信息,以及CGridView Here
答案 2 :(得分:0)
清除最后一个逗号的最佳方法是.. 修剪( '',字符串) 问候