首页 > 代码库 > Yii CGridView 基本使用(二)CCheckBoxColumn ButtonColumn afterAjaxUpdate

Yii CGridView 基本使用(二)CCheckBoxColumn ButtonColumn afterAjaxUpdate

添加 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'),
		),
        ....

     PS:在这里只谈我常用的部分,详细请看文档:CGridView

Yii CGridView 基本使用(二)CCheckBoxColumn ButtonColumn afterAjaxUpdate