CGridView 以表格的形式显示数据,CGridView 也支持分页和排序,CGridView最基本的用法和ListView类型,也是通过设置data provider,通常是CActiveDataProvider。
修改上个例子Yii Framework 开发教程(31) Zii组件-DetailView 示例,把ListView该为GridView:
<?php $this->widget('zii.widgets.grid.CGridView', array( 'dataProvider'=>$dataProvider, 'ajaxUpdate'=>false, 'template'=>'{pager}{summary}{items}{pager}', )); ?>
显示结果如下:
可以看到GridView缺省显示了所有的字段,并使用缺省的格式显示字段,如果需要控制字段显示和格式,可以通过配置CGridView::columns属性来实现。GridView的每列为一个CGridColumn对象:
重新定义GridView的columns属性如下:
<?php $this->widget('zii.widgets.grid.CGridView', array( 'id'=>'person-grid', 'dataProvider'=>$dataProvider, 'htmlOptions'=>array('style'=>'width:740px'), 'pager'=>array( 'maxButtonCount'=>'7', ), 'columns'=>array( array( 'header'=>'Name', 'type'=>'raw', 'value'=>'CHtml::link($data->FirstName . " " . $data->LastName, $this->grid->controller->createUrl ("view",array("CustomerId"=>$data->CustomerId)))', ), 'Company', array( 'class'=>'CLinkColumn', 'header'=>'Email', 'imageUrl'=>'images/email.png', 'labelExpression'=>'$data->Email', 'urlExpression'=>'"mailto://".$data->Email', 'htmlOptions'=>array('style'=>'text-align:center'), ), array( 'class'=>'CButtonColumn', 'deleteConfirmation'=>'Are you sure to delete this item?', ), ), )); ?>