天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

php分頁思路以及在ZF中的使用

只需要得到兩個變量就成功了一半:
每頁要顯示的記錄數$pageSize
表中總的數據量 $rowCount
有了以上兩個變量,我們就可以得出 共有幾頁了$pageCount
然后通過for循環,比如總共有13個頁面,那么很容易就能通過for循環輸出頁數
復制代碼 代碼如下:
$nav='';//用來保存頁數的一個變量
for ($i=1;$i<=13;$i++)
{
  $nav.="<a href='index.php?page=".$i."'>第".$i."頁</a> ";
}

以上的for循環將輸出如
第1頁,第2頁,第3頁,第4頁,第5頁,第6頁,第7頁,第8頁,第9頁,第10頁,第11頁,第12頁,第13頁
如果我們只想每次只顯示十個頁面呢?比如1-10頁,11-20頁
很簡單,只要稍微修改下for循環即可實現
復制代碼 代碼如下:
$step= floor(($pageNow-1)/10)*10+1;
for ($i=$step;$i<=$step+10;$i++)
{
  $nav.="<a href='index.php?page=".$i."'>第".$i."頁</a> ";
}

比如,當前頁面$pageNow如何在1~10之間的話,那么$step=0
當前頁面$pageNow如何在11~20之間的話,那么$step=10
當前頁面$pageNow如何在21~30之間的話,那么$step=20
參考具體的實現過程的代碼,我們不難發現,for循環的第二個條件只需要加上10就可以實現每次只顯示10也的情況了,我們將這一步分裝在fenyePage類中的getLink()方法中
話又說回來,如何才能得到$pageSize和$rowCount兩個變量的值呢?
$pageSize可以又程序員自己指定,$rowCount可以借助一個簡單的執行sql語句的函數就能得到
復制代碼 代碼如下:
<?php
/**
* $sql語句:①獲取數據②獲取總記錄數
*/
class fenyePage{
public $pageSize=5;//每頁顯示的數量-->程序員指定的
public $rowCount;//這是從數據庫中獲取的(形如SELECT COUNT(id) FROM TABLE)用來保存總共有多少條記錄
public $pageNow;//通過$_GET['page']獲取的,用來保存當前所在的頁碼
public $pageCount;//計算得到的,用來保存總共有多少頁
public $res_arr;//用來保存要顯示到頁面的數據(比如保存SELECT * FROM TABLE LIMIT 0,10 檢索的數據)
public $nav;//顯示第幾頁第幾頁的導航條
/**
* 取得當前頁面的超鏈接
*
* @author 小飛 2012/5/30
*/
public function getLink()
{
$this->nav='';
$this->pageCount=ceil(($this->rowCount/$this->pageSize));
$step= floor(($this->pageNow-1)/10)*10+1;
if ($this->pageNow>10)
{
$this->nav.=" <a href='index.php?page=".($step-1)."'> << </a> ";//整體每10頁向前翻
}
if ($this->pageNow!=1)
{
$this->nav.="<a href='index.php?page=".($this->pageNow-1)."'> </a> ";
}
if ($this->pageNow!=1)
{
$this->nav.="<a href='index.php?page=1'>首頁</a> ";
}
for ($start=$step;$start<$step+10 && $start<=$this->pageCount;$start++)
{
$this->nav.="<a href='index.php?page=".$start."'>".$start."</a> ";
}
if ($this->pageNow!=$this->pageCount)
{
$this->nav.="<a href='index.php?page=".$this->pageCount."'>末頁</a> ";
}
if ($this->pageNow!=$this->pageCount)
{
$this->nav.=" <a href='index.php?page=".($this->pageNow+1)."'></a>";
}
if ($this->pageCount>10 && $this->pageNow<$this->pageCount-8){
$this->nav.=" <a href='index.php?page=".($step+10)."'> >> </a>";//整體每10頁向后翻
}
$this->nav.="/共有".$this->pageCount."頁";
}
}
?>

由于zf中操作數據庫的任務由model層來完成,所以,我將獲取$rowCount的值的函數放在了對應的表model中
比如:我是操作order表的
那么當我要顯示所有訂單信息的時候,我通過order類中的showorder()方法取得$rowCount的值,并將其付給分頁類中的$rowCount屬性
同樣,將要顯示在頁面上的數據信息也一并付給了分頁類中的$res_arr屬性
這樣,我們就可以很容易的通過實例化一個分頁類(fenyePage),然后將其通過參數傳給showorder()函數,由該函數完成以下動作:
①要顯示在頁面上的信息
②表中總共有多少條記錄
復制代碼 代碼如下:
/**
* 根據指定的用戶id,查詢該用戶的歷史訂餐記錄
*
* @author 小飛 2012/5/30
* @param $id 用戶id
* @param $fenye 實例化的一個對象,用來處理分頁
* @todo $sql1語句 "select * from table where * limit 0,10" 該sql語句主要用來檢索數據庫中的數據,用以顯示在view層
* @todo $sql2語句 "select count(id) from table" 該sql語句用來得出總的數據量
*/
public function showorder($id=null,$fenye=null)
{
$db = $this->getAdapter();
$select=$db->select();
$select->from(array('o' => 'order'),array('o.id','o.user_id','o.user_name','o.food_name','o.food_price','o.order_time','o.order_state'));
if ($id!=null){
$select->where('o.user_id=?',$id);
}
$select->join(array('d'=>'department'),'o.dep_id = d.id','d.dep_name');
if($fenye!=null){
$select->limit($fenye->pageSize,($fenye->pageNow-1)*$fenye->pageSize);
}
$sql1=$select->__toString();
//該sql語句主要用來計算總的數據量
$sql2="SELECT COUNT(id) FROM `order`";
$fenye->res_arr=$db->fetchAll($sql1);//將要顯示的數據存儲到分頁類的$res_arr屬性當中,方便調用
$rowCount=$db->fetchAll($sql2);//將表中的總數據量保存到分頁類的rowCount屬性當中
$fenye->rowCount=$rowCount[0]['COUNT(id)'];
$fenye->getLink();
return $fenye->res_arr;
}

至此,分頁類的功能就已經實現了
原創文章:WEB開發_小飛

php技術php分頁思路以及在ZF中的使用,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 扒开粉嫩的小缝末成年小美女 | 中文字幕亚洲乱码熟女在线萌芽 | 欧美又粗又长又大AAAA片 | 国产亚洲精品香蕉视频播放 | 久久久久久久久久综合情日本 | AV多人爱爱XXx | 国产高清视频在线观看97 | 青草精品国产福利在线视频 | 国产成人无码免费精品果冻传媒 | 精品久久久99大香线蕉 | 高清欧美一区二区三区 | 老阿姨儿子一二三区 | 在线播放免费人成毛片视频 | qvod欧美电影| 动漫美女搞鸡 | 男人和女人一级黄色大片 | 艳鉧动漫1~6全集观看在线 | 大乳牛奶女magnet | 精品久久中文字幕有码 | 2021精品乱码多人收藏 | 久久精品中文字幕免费 | 久久热在线视频精品店 | 久久这里只精品热在线99 | 日本美女靠逼 | 久久婷婷久久一区二区三区 | 亚洲国产精品久久精品成人网站 | 九九热在线视频观看这里只有精品 | 97豆奶视频国产 | 色欲AV精品人妻一二三区 | 国产精品资源网站在线观看 | 欧美麻豆一精品一AV一免费 | 亚洲精品午夜aaa级久久久久 | 嗯啊…嗯np男男双性总受 | 国产成人综合在线视频 | 亚洲午夜精品A片久久不卡蜜桃 | 亚瑟天堂久久一区二区影院 | 久久国产36精品色熟妇 | 花蝴蝶高清在线视频免费观看 | 两个奶头被吃得又翘又痛 | 99久久中文字幕伊人情人 | 亚洲免费一 |