yii的分页类CLinkPager默认是不支持显示共x页的,那么现在需求来了,要在分页的后面显示共多少页,怎么办喃?我们来看解决办法
1、默认的CLinkPager显示的效果
上面这里写了css的样式哈,我们来看pager代码:
<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,看上去也是非常的狠狠简单呐,废话不多少,来来先看代码:
<?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里面是怎么使用的,那是简单的不能再过于简单了。
<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、
$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、
$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中传入参数:
array(\"pages\" => $pager)
视图中加入:
$this->widget(\'CLinkPager\',array( \'header\'=>\'\', \'firstPageLabel\' => \'首页\', \'lastPageLabel\' => \'末页\', \'prevPageLabel\' => \'上一页\', \'nextPageLabel\' => \'下一页\', \'pages\' => $pages, \'maxButtonCount\'=>8, ) );
分页思想:
1、计算数据库中总的条数
2、分页大小
3、设置偏移量limit
在Yii中,分页时会用这个类CDBcritria进行数据库查询很重要,这样分页很简单。
本文地址:https://www.stayed.cn/item/13054
转载请注明出处。
本站部分内容来源于网络,如侵犯到您的权益,请 联系我