VB.net 2010 视频教程 VB.net 2010 视频教程 python基础视频教程
SQL Server 2008 视频教程 c#入门经典教程 Visual Basic从门到精通视频教程
当前位置:
首页 > PHP >
  • 理解php分页思路方法详解

在php中分页相对来说很是简单的,我们只要理解到几点就好如pagesize,count,page这几个变量,总体多少页,当前是第几页,第页要显示几条记录,我们只要一个公式可以算出来。

只需要得到两个变量就成功了一半:每页要显示的记录数$pageSize,表中总的数据量 $rowCount,有了以上两个变量,我们就可以得出 共有几页了$pageCount,然后通过for循环,比如总共有13个页面,那么很容易就能通过for循环输出页数,代码如下:

  1. $nav='';//用来保存页数的一个变量  
  2. for ($i=1;$i<=13;$i++)  
  3. {  
  4.   $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循环即可实现,代码如下:

  1. $stepfloor(($pageNow-1)/10)*10+1;  
  2. for ($i=$step;$i<=$step+10;$i++)  
  3. {  
  4.   $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语句的函数就能得到,代码如下:

  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. * @author 小飞 2012/5/30  
  16. */  
  17. public function getLink()  
  18. {  
  19. $this->nav='';  
  20. $this->pageCount=ceil(($this->rowCount/$this->pageSize));  
  21. $stepfloor(($this->pageNow-1)/10)*10+1;  
  22. if ($this->pageNow>10)  
  23. {  
  24. $this->nav.=" <a href='index.php?page=".($step-1)."'> << </a> ";//整体每10页向前翻  
  25. }  
  26. if ($this->pageNow!=1)  
  27. {  
  28. $this->nav.="<a href='index.php?page=".($this->pageNow-1)."'> 上一页</a> ";  
  29. }  
  30. if ($this->pageNow!=1)  
  31. {  
  32. $this->nav.="<a href='index.php?page=1'>首页</a> ";  
  33. }  
  34. for ($start=$step;$start<$step+10 && $start<=$this->pageCount;$start++)  
  35. {  
  36. $this->nav.="<a href='index.php?page=".$start."'>".$start."</a> ";  
  37. }  
  38. if ($this->pageNow!=$this->pageCount)  
  39. {  
  40. $this->nav.="<a href='index.php?page=".$this->pageCount."'>末页</a> ";  
  41. }  
  42. if ($this->pageNow!=$this->pageCount)  
  43. {  
  44. $this->nav.=" <a href='index.php?page=".($this->pageNow+1)."'>下一页</a>";  
  45. }  
  46. if ($this->pageCount>10 && $this->pageNow<$this->pageCount-8){  
  47. $this->nav.=" <a href='index.php?page=".($step+10)."'> >> </a>";//整体每10页向后翻  
  48. }  
  49. $this->nav.="/共有".$this->pageCount."页";  
  50. }  
  51. }  
  52. ?> 

同样,将要显示在页面上的数据信息也一并付给了分页类中的$res_arr属性,这样,我们就可以很容易的通过实例化一个分页类(fenyePage),然后将其通过参数传给showorder()函数,由该函数完成以下动作: 

①要显示在页面上的信息 

②表中总共有多少条记录

总结分页最核心的几句代码:

$this->pageCount=ceil(($this->rowCount/$this->pageSize)); 

$step= floor(($this->pageNow-1)/10)*10+1;

再就是sql中的select * from table where * limit 0,10,也就是本实例中的$select->limit($fenye->pageSize,($fenye->pageNow-1)*$fenye->pageSize); 了。



出处:http://www.phpfensi.com/php/20140103/1035.html


相关教程