添加 CCheckBoxColumn :
有时也许我们会需要一个复选框,来对每一行进行选择,这时,我们可以增加一列,用 CCheckBoxColumn 类:
- <?php $this->widget('zii.widgets.grid.CGridView', array(
- 'id'=>'post-grid',
- 'dataProvider'=>$model->search(),
- 'filter'=>$model,
- 'columns'=>array(
- array(
- 'selectableRows' => 2, //允许多选,改为 0 时代表不允许修改,1 的话为单选
- 'class' => 'CCheckBoxColumn',//复选框
- 'headerHtmlOptions' => array('width'=>'18px'),//头部的 html 选项
- 'checkBoxHtmlOptions' => array('name' => 'myname','class'=>'myclass'), //复选框的 html 选项
- ),
- 'post_id',
- 'title',
- 'content',
- 'tags',
- 'status',
- 'create_time',
- 'update_time',
- 'author_id',
- 'is_delete',
- array(
- 'name'=>'is_delete',
- 'value'=>'is_delete?"是":"否"', //value 是可以执行 php 语句的哦
- 'filter' => array(0=>'否',1=>'是'), //自己定义搜索过滤的方式,这里为 是 和 否 的下拉菜单
- 'htmlOptions'=>array('class'=>'delete'), //可以定义 html 选项,这里是定义了带一个 delete 的类
- ),
- array(
- 'class'=>'CButtonColumn',
- ),
- ),
- ));
修改ButtonColumn:
注意到列表每一项的最后三个小图标吗?不需要的话当然是直接删了,那要是只要其中某几个呢?可以加一个 template 参数:
- array(
- 'class'=>'ButtonColumn',
- 'template'=>"{view} {update}",
- ),
- array(
- 'class'=>'ButtonColumn',
- 'template'=>"{view} {update} {print}",
- 'buttons'=>array(
- 'print'=>array(
- 'label'=>'打印',
- 'url'=>'Yii::app()->controller->createUrl("print", array("id"=>$data->post_id))',
- 'options'=>array("target"=>"_blank"),
- ),
- ),
- ),
刷新时触发 Javascript:
如果你想在每次搜索之后触发一些 Javascript ,Yii 也提供了这个选项,你只要写成一个函数然后设置 afterAjaxUpdate 就好,记住这只是在 ajax 请求完成之后调用的,如果你想在 页面 一开始加载完成就调用的话需要另外加到页面的 Javascript
- $js = <<<_JS_
- function(){
- alert('The ajax finish');
- }
- _JS_;
- $this->widget('zii.widgets.grid.CGridView', array(
- 'id'=>'post-grid',
- 'dataProvider'=>$model->search(),
- 'filter'=>$model,
- 'afterAjaxUpdate'=>$js, //看这里,ajax 之后调用的 javascript 在这里....
- 'columns'=>array(
- array(
- 'selectableRows' => 2, //允许多选,改为 0 时代表不允许修改,1 的话为单选
- 'class' => 'CCheckBoxColumn',//复选框
- 'headerHtmlOptions' => array('width'=>'18px'),
- 'checkBoxHtmlOptions' => array('name' => 'myname','class'=>'myclass'),
- ),
- ....