/*
* 统计功能: 统计每日的运费
*/
public function statistics()
{
$criteria = new CDbCriteria;
$criteria->select = 'remitdate, sum(rate) AS dayrate';
$criteria->group = 'remitdate';
return new CActiveDataProvider(get_class($this), array(
'criteria'=>$criteria,
'sort'=>array(
// 表头设置点击排序的字段
'attributes'=>array(
'remitdate',
'dayrate'=>array(
'asc'=>'dayrate',
'desc'=>'dayrate DESC',
)
),
'defaultOrder'=>'remitdate desc',
),
));
}
Controller层:
复制代码 代码如下:
/**
* 运单统计功能:
* 按日期统计
*/
public function actionReport()
{
$model=new Delivery('statistics');
$model->unsetAttributes(); // clear any default values
$this->render('report',array(
'model'=>$model,
));
}
View层:
复制代码 代码如下:
<?php $this->widget('zii.widgets.grid.CGridView', array(
'id'=>'delivery-grid',
'dataProvider'=>$model->statistics(),
'filter'=>$model,
'columns'=>array(
'remitdate',
'dayrate',
array(
'class'=>'CButtonColumn',
),
),
));
?>
优点: 可以使用自带的样式; 缺点: 效率略低.
第五种:Ajax分页
YII中ajax分页有多种实现方法,比较传统的就是在view中写JS来实现,大概的就是这样:
在view中js大概逻辑是这样
复制代码 代码如下:
$('#listview .yiiPager a').live('click',function(){
$.ajax({
url:$(this).attr('href'),
success:function(html){
$('#listview').html(html);
}
});
return false;//阻止a标签
});
然后在controller中判断ajax请求,再使用renderPartial方法渲染局部List视图,然后局部视图会被view中的ajax方法填充到局部刷新的div中。controller的大概逻辑是:
复制代码 代码如下:
if (Yii::app()->request->isAjaxRequest) {
$this->renderPartial('_comments',array(
'model' => $model,
'comments' => $comments,//在局部视图中foreach得到每条数据
'pages' => $pages,
));
Yii::app()->end();
}
后来发现YII中的CListview更方便,封装了分页,foreach显示list,还支持数据排序。具体的可以在YII的API手册中发掘。使用CListview是默认ajax分页的,使用方法如下:
controller中:
复制代码 代码如下:
$criteria = new CDbCriteria();
$criteria->order = '`create_time` DESC';
$dataProvider = new CActiveDataProvider('Comments', array(
'pagination'=>array(
'pageSize'=>Yii::app()->params['commentsPerPage'],//设置分页条数以确定取出数据的条数
),
'criteria'=>$criteria,
));
$this->render('comments',array(
'model' => $model,
'dataProvider' => $dataProvider,
));
然后在view中:
复制代码 代码如下:
<?php $this->widget('zii.widgets.CListView', array(
'dataProvider'=>$dataProvider,
'itemView'=>'_comments',
//'ajaxUpdate'=> false,//这样就不会AJAX翻页
'pager' => array(//pager 的配置信息。默认为<CODE>array('class'=>'CLinkPager')</CODE>.也可以自己配置
'nextPageLabel' => '下一页 »',
'prevPageLabel' => '« 上一页'
),
//在这里还可以配置一些排序规则,具体可以查阅手册
));
?>
这样就实现了Ajax分页,很方便。