WEB开发 发表于 2012-12-17 21:44:22

分页的思路以及在ZF中的使用

<div id="cnblogs_post_body">分页思路:
只需要得到两个变量就成功了一半:

[*]每页要显示的记录数$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语句的函数就能得到

<div class="cnblogs_code"> 1 <?php 2 /** 3 * $sql语句:①获取数据②获取总记录数 4*/ 5 class fenyePage{ 6   public $pageSize=5;//每页显示的数量-->程序员指定的 7   public $rowCount;//这是从数据库中获取的(形如SELECT COUNT(id) FROM TABLE)用来保存总共有多少条记录 8   public $pageNow;//通过$_GET['page']获取的,用来保存当前所在的页码 9   public $pageCount;//计算得到的,用来保存总共有多少页10   public $res_arr;//用来保存要显示到页面的数据(比如保存SELECT * FROM TABLE LIMIT 0,10 检索的数据)11   public $nav;//显示第几页第几页的导航条12   13   /**14    * 取得当前页面的超链接15    * 16    * @author 小飞 2012/5/3017      */18   public function getLink()19     { 20         $this->nav='';21         $this->pageCount=ceil(($this->rowCount/$this->pageSize));22         $step= floor(($this->pageNow-1)/10)*10+1; 23         if ($this->pageNow>10)24       {25             $this->nav.="   <a href='index.php?page=".($step-1)."'> << </a>";//整体每10页向前翻26       }27         if ($this->pageNow!=1) 28       {29             $this->nav.="<a href='index.php?page=".($this->pageNow-1)."'>上一页</a>";30       } 31         if ($this->pageNow!=1)32       {33             $this->nav.="<a href='index.php?page=1'>首页</a>   ";34       }35         for ($start=$step;$start<$step+10 && $start<=$this->pageCount;$start++)36       {37             $this->nav.="<a href='index.php?page=".$start."'>".$start."</a>"; 38       } 39         if ($this->pageNow!=$this->pageCount)40       {41             $this->nav.="<a href='index.php?page=".$this->pageCount."'>末页</a>   ";42       }43         if ($this->pageNow!=$this->pageCount)44       {45             $this->nav.="   <a href='index.php?page=".($this->pageNow+1)."'>下一页</a>";46       }47         if ($this->pageCount>10 && $this->pageNow<$this->pageCount-8){48             $this->nav.="   <a href='index.php?page=".($step+10)."'> >> </a>";//整体每10页向后翻49       }50         $this->nav.="/共有".$this->pageCount."页";51     }52 }53 ?>
页: [1]
查看完整版本: 分页的思路以及在ZF中的使用