理解php分页思路方法详解
在php中分页相对来说很是简单的,我们只要理解到几点就好如pagesize,count,page这几个变量,总体多少页,当前是第几页,第页要显示几条记录,我们只要一个公式可以算出来。
只需要得到两个变量就成功了一半:每页要显示的记录数$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. "页" ; } } ?>同样,将要显示在页面上的数据信息也一并付给了分页类中的$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); 了。
查看更多关于理解php分页思路方法详解 - php分页的详细内容...
声明:本文来自网络,不代表【好得很程序员自学网】立场,转载请注明出处:http://haodehen.cn/did27953