源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

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

  • 时间:2022-08-14 21:54 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:php分页思路以及在ZF中的使用
只需要得到两个变量就成功了一半: 每页要显示的记录数$pageSize 表中总的数据量 $rowCount 有了以上两个变量,我们就可以得出 共有几页了$pageCount 然后通过for循环,比如总共有13个页面,那么很容易就能通过for循环输出页数
[url=index.php?page=]}
以上的for循环将输出如 第1页,第2页,第3页,第4页,第5页,第6页,第7页,第8页,第9页,第10页,第11页,第12页,第13页 如果我们只想每次只显示十个页面呢?比如1-10页,11-20页 很简单,只要稍微修改下for循环即可实现 比如,当前页面$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语句的函数就能得到
[url=index.php?page=]} 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()函数,由该函数完成以下动作: ①要显示在页面上的信息 ②表中总共有多少条记录
至此,分页类的功能就已经实现了 原创文章:WEB开发_小飞
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部