我是 yii 框架的新手。我有 2 个模型(Tables
有很多PeriodeDatas
)并希望在表索引视图中显示模型PeriodeDatas
中的数据CGridView
,但无法使其正常工作。
表格列
The followings are the available columns in table 'nkr_tables':
@property integer $id
@property string $title
@property string $periode
表模型关系
'periodeData' => array(self::HAS_MANY, 'PeriodeDatas', 'table_id')
PeriodeDatas列
The followings are the available columns in table 'nkr_periode_datas':
@property integer $id
@property integer $table_id
@property string $year
PeriodeDatas模型关系
'table' => array(self::BELONGS_TO, 'Tables', 'table_id')
表控制器
public function actionIndex()
{
$model = new Tables('search');
$model->unsetAttributes();
if (isset($_GET['Tables']))
$model->attributes = $_GET['Tables'];
$this->render('index', array('model' => $model));
}
表格视图
$this->widget('zii.widgets.grid.CGridView',
array(
'id'=>'tables-grid',
'dataProvider'=>$model->search(),
'filter'=>$model,
'columns' => array(
array(
'name' => 'title',
'header' => 'Data Title'
),
'periode',
array(
'name' => 'periodeData.year',
'header' => 'Tahun'
)
),
'selectionChanged'=>'function(id) { location.href = "'.$this->createUrl('tables/view').'/"+$.fn.yiiGridView.getSelection(id);}'
)
);
结果: http: //prntscr.com/18jpp1
如何在表格视图中显示模型year
?PeriodeDatas
CGridView
*抱歉英语不好
更新:
我尝试添加'value' => '$data->periodeData->year'
但收到错误Trying to get property of non-object
更新:
我试过'value' => '$data->periodeData[0]->year'
了,它正确显示了年份,但如果桌子上只有 1 条记录。当表上有超过 1 条记录时,会产生错误Undefined offset: 0
然后我试着'value' => '$data->periodeData[$data->id]->year'
给我错误Undefined index: 1