CGridView 以表格的形式顯示資料,CGridView 也支援分頁和排序,CGridView最基本的用法和ListView類型,也是通過設定 data provider,通常是CActiveDataProvider。
修改上個例子Yii Framework 開發教程(31) Zii組件-DetailView 樣本,把ListView該為GridView:
widget('zii.widgets.grid.CGridView', array('dataProvider'=>$dataProvider,'ajaxUpdate'=>false,'template'=>'{pager}{summary}{items}{pager}',)); ?>
可以看到GridView預設顯示了所有的欄位, 並使用預設的格式顯示欄位,如果需要控制欄位顯示和格式,可以通過配置 CGridView::columns屬性來實現。GridView的 每列為一個CGridColumn對象:
CGridColumn為所有Grid 清單項目的基類,表格的每例可以有一個表頭,多個資料單元,和一個可選的表尾儲存格。
CButtonColumn 表示該儲存格為一個或多個按鈕,預設顯示三個按鈕, “view”, “update” 和”delete”,可以通過設定 buttons 和 template來更改。
CCheckBoxColumn 表示該儲存格為Checkbox,支援唯讀,單選或多選,通過配置selectableRows來修改
CDataColumn 表示該單元為資料或是運算式,通過配置name或value,前者表示資料模型的屬性名稱,後者代碼一個PHP表達 式。
CLinkColumn 表示一個超連結,通過配置 label , url或 imageUrl來設定連結。
重新定義GridView的columns屬性如下:
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?',),),));?>
點擊姓名可以顯示DetailView。 ButtonColumn 的update,search,delete沒有添加對應的view ,就留給你自己加上了。
以上就是PHP開發架構Yii Framework教程(32) Zii組件-GridView樣本的內容,更多相關內容請關注topic.alibabacloud.com(www.php.cn)!