我想创建一个像Yii Booster Gridview table
这样的表格这是我在控制器中的代码:
$rawData=Jobspecs::model()->with('customer')->findAll();
$gridDataProvider=new CArrayDataProvider($rawData, array(
'id'=>'user',
'sort'=>array(
'attributes'=>array(
'id', 'customer',
),
),
));
$gridColumns = array(
array('name'=>'id', 'header'=>'Js No.', 'htmlOptions'=>array('style'=>'width: 60px')),
array('name'=>'WHAT TO PUT HERE TO SHOW CUSTOMER NAME', 'header'=>'Customer Name'),
array(
'htmlOptions' => array('nowrap'=>'nowrap'),
'class'=>'booster.widgets.TbButtonColumn',
'viewButtonUrl'=>null,
)
);
在我的模型sapcustomers中:
return array(
'customer'=>array(self::BELONGS_TO, 'Sapcustomers', 'customer'),
);
jobspecs模型
return array(
'cardname'=>array( self::HAS_MANY, 'Jobspecs', 'customer' ),
);
我的观点
<?php
$this->widget(
'booster.widgets.TbGridView',
array(
'type' => 'bordered',
'dataProvider' => $gridDataProvider,
'template' => "{items}",
'columns' => $gridColumns,
)
);
?>
你可以看到我加入了sapcustomers和jobspecs表。我的问题是我需要在$gridcolums
上放置哪些代码来显示表sapcustomer中的客户名称数据。谢谢你的帮助
答案 0 :(得分:1)
我认为这应该适合你:
$gridColumns = array(
[...]
array(
'name'=>'customer',
'value'=>'$data->customer->name',
'header'=>'Customer Name'
),
);
<强>解释强>
$data
代表实际行中的Jobspecs-model
。然后,您可以访问相关的customer
和他的name
。