yii的分页类CLinkPager默认是不支持显示共x页的,那么现在需求来了,要在分页的后面显示共多少页,怎么办喃?我们来看解决办法
1、默认的CLinkPager显示的效果
上面这里写了css的样式哈,我们来看pager代码:
1
2
3
4
5
6
7
8
9
10
11
12
|
<div class = "page-link" >
<?php $this ->widget( 'CLinkPager' , array (
'header' => '' ,
'firstPageLabel' => '首页' ,
'lastPageLabel' => '尾页' ,
'prevPageLabel' => '<' ,
'nextPageLabel' => '>' ,
'pages' => $pages ,
'maxButtonCount' =>5,
'htmlOptions' => array ( 'class' => 'page-link' ), //分页要使用的css样式
));?>
</div>
|
2、我们来看想要的分页类效果
也就是说后面增加显示了共多少页,这个怎么做到的喃?这里我稍微小小的扩展了一下widget组件CLinkPager,看上去也是非常的狠狠简单呐,废话不多少,来来先看代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
|
<?php
/**
* 分页组建ClinkPager扩展
* @description page-tab-tog为分页的样式class
* @author <[<xm 杭州>]>
* @time 2016-01-29
* @example
* <div class="page-tab-tog">
* <?php $this->widget('MLinkPager',array(
* 'header' => '',
* 'firstPageLabel' => '首页',
* 'lastPageLabel' => '尾页',
* 'prevPageLabel' => '<',
* 'nextPageLabel' => '>',
* 'pages' => $pages,
* 'maxButtonCount'=>5,
* 'htmlOptions' => array('class' => 'page-tab-tog'),
* ));?>
* </div>
*/
class MLinkPager extends CLinkPager
{
//设置为true的时候,显示共X页,$this->forceTotalPage值优先该值
public $mCountPage = false;
//是否强制显示共x页,设置为true时,$this->mCountPage和$this->getPageRange()无效
public $forceTotalPage = false;
public function init()
{
}
public function run()
{
$this ->registerClientScript();
$buttons = $this ->createPageButtons();
list( $beginPage , $endPage )= $this ->getPageRange();
if ( $this ->forceTotalPage)
{
$buttons [] = CHtml::tag( 'li' , array ( 'class' => 'totle' ), '共' . $this ->getPageCount(). '页' );
}
else
{
if ( $this ->mCountPage && $endPage > 0)
{
$buttons [] = CHtml::tag( 'li' , array ( 'class' => 'totle' ), '共' . $this ->getPageCount(). '页' );
}
}
if ( empty ( $buttons ))
return ;
echo $this ->header;
echo CHtml::tag( 'div' , $this ->htmlOptions,implode( "\n" , $buttons ));
echo $this ->footer;
}
}
|
有人说了,一看那么一堆代码,头疼,你这玩意怎么能以最快的速度见到效果呢?来来我们继续看怎么使用,首先呢,你需要先把上面的扩展MLinkPager原封不动的拷贝到本地的components目录下的MlinkPager文件里,什么,你没有这个文件,自己创建,^~^!好了以后咱们来看下view里面是怎么使用的,那是简单的不能再过于简单了。
1
2
3
4
5
6
7
8
9
10
11
12
13
|
<div class = "page-tab-tog" >
<?php $this ->widget( 'MLinkPager' , array (
'header' => '' ,
'firstPageLabel' => '首页' ,
'lastPageLabel' => '尾页' ,
'prevPageLabel' => '<' ,
'nextPageLabel' => '>' ,
'pages' => $pages ,
'maxButtonCount' =>5,
'mCountPage' => true, //!!!注意看这里,加一行代码就ok了
'htmlOptions' => array ( 'class' => 'page-tab-tog' ),
));?>
</div>
|
什么?你刚睡醒眼神不好,没看出来区别?注意看MLinkPager的配置项mCountPage,这个设置为true就万事大吉了!
特别说明:如果你的列表没有数据的话,分页是不显示页码的,但是如果有刁蛮产品要的需求是没有列表数据,但但但你必须得吧共0页显示出来,我们的MlinkPager只需要设置下配置项forceTotalPage为true即可,此时设置mCountPager无效了咯,具体详细请看MlinkPage类,次类可自己再进行扩展
下面给大家介绍在在yii中使用分页
yii中使用分页很方便,如下两种方法:
在控制器中:
1、
1
2
3
4
5
6
|
$criteria = new CDbCriteria(); //new cdbcriteria数据库<br>$criteria->id = 'id ASC'; //排序规则
$count = Exchange::model()-> count ( $criteria );
$pager = new CPagination( $count );
$pager ->pageSize=30;
$pager ->applyLimit( $criteria );
$categoryInfo = Category::model()->findAll( $criteria ); //根据条件查询
|
2、
1
2
3
4
5
6
7
8
9
|
$criteria = new CDbCriteria();
$criteria ->order = 'id ASC' ;
$criteria ->addCondition( 'status=1' ); //根据条件查询
$criteria ->addCondition( 'exchange_status=0' );
$count = Exchange::model()-> count ( $criteria );
$pager = new CPagination( $count );
$pager ->pageSize=30;
$pager ->applyLimit( $criteria );
$exchangeInfo = Exchange::model()->findAll( $criteria );
|
render中传入参数:
1
|
array ( "pages" => $pager )
|
视图中加入:
1
2
3
4
5
6
7
8
9
10
|
$this ->widget( 'CLinkPager' , array (
'header' => '' ,
'firstPageLabel' => '首页' ,
'lastPageLabel' => '末页' ,
'prevPageLabel' => '上一页' ,
'nextPageLabel' => '下一页' ,
'pages' => $pages ,
'maxButtonCount' =>8,
)
);
|
分页思想:
1、计算数据库中总的条数
2、分页大小
3、设置偏移量limit
在Yii中,分页时会用这个类CDBcritria进行数据库查询很重要,这样分页很简单。