加入收藏 | 设为首页 | 会员中心 | 我要投稿 应用网_丽江站长网 (http://www.0888zz.com/)- 科技、建站、数据工具、云上网络、机器学习!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

理解php分页思路方法分析

发布时间:2022-07-18 15:07:49 所属栏目:PHP教程 来源:互联网
导读:在php中分页相对来说很是简单的,我们只要理解到几点就好如pagesize,count,page这几个变量,总体多少页,当前是第几页,第页要显示几条记录,我们只要一个公式可以算出来。 只需要得到两个变量就成功了一半:每页要显示的记录数$pageSize,表中总的数据量 $row
    在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> ";  
    }
  
    $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> ";  
    }  
     ?>
    同样,将要显示在页面上的数据信息也一并付给了分页类中的$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); 了。

(编辑:应用网_丽江站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读