程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> YII CLinkPager分頁類擴展增加顯示共多少頁,yiiclinkpager

YII CLinkPager分頁類擴展增加顯示共多少頁,yiiclinkpager

編輯:關於PHP編程

YII CLinkPager分頁類擴展增加顯示共多少頁,yiiclinkpager


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進行數據庫查詢很重要,這樣分頁很簡單。

您可能感興趣的文章:

  • Yii使用CLinkPager分頁實例詳解

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved