时间:2021-07-01 10:21:17 帮助过:58人阅读
输出如
- <br>$nav='';//用来保存页数的一个变量 <br>for ($i=1;$i<=13;$i++) <br>{ <br> $nav.="<a href='index.php?page=".$i."'>第".$i."页</a> "; <br>} <br> <br>以上的for循环将
- <br>$step= floor(($pageNow-1)/10)*10+1; <br>for ($i=$step;$i<=$step+10;$i++) <br>{ <br> $nav.="<a href='index.php?page=".$i."'>第".$i."页</a> "; <br>} <br> <br>比如,当前页面$pageNow如何在1~10之间的话,那么$step=0 <br>当前页面$pageNow如何在11~20之间的话,那么$step=10 <br>当前页面$pageNow如何在21~30之间的话,那么$step=20 <br>参考具体的实现过程的代码,我们不难发现,for循环的第二个条件只需要加上10就可以实现每次只显示10也的情况了,我们将这一步分装在fenyePage类中的getLink()方法中 <br>话又说回来,如何才能得到$pageSize和$rowCount两个变量的值呢? <br>$pageSize可以又程序员自己指定,$rowCount可以借助一个简单的执行sql语句的函数就能得到 <br><span><u></u></span> 代码如下:<pre class="brush:php;toolbar:false layui-box layui-code-view layui-code-notepad"><ol class="layui-code-ol"><li><br><?php <br>/** <br>* $sql语句:①获取数据②获取总记录数 <br>*/ <br>class fenyePage{ <br>public $pageSize=5;//每页显示的数量-->程序员指定的 <br>public $rowCount;//这是从数据库中获取的(形如SELECT COUNT(id) FROM TABLE)用来保存总共有多少条记录 <br>public $pageNow;//通过$_GET['page']获取的,用来保存当前所在的页码 <br>public $pageCount;//计算得到的,用来保存总共有多少页 <br>public $res_arr;//用来保存要显示到页面的数据(比如保存SELECT * FROM TABLE LIMIT 0,10 检索的数据) <br>public $nav;//显示第几页第几页的导航条 <br>/** <br>* 取得当前页面的超链接 <br>* <br>* @author 小飞 2012/5/30 <br>*/ <br>public function getLink() <br>{ <br>$this->nav=''; <br>$this->pageCount=ceil(($this->rowCount/$this->pageSize)); <br>$step= floor(($this->pageNow-1)/10)*10+1; <br>if ($this->pageNow>10) <br>{ <br>$this->nav.=" <a href='index.php?page=".($step-1)."'> << </a> ";//整体每10页向前翻 <br>} <br>if ($this->pageNow!=1) <br>{ <br>$this->nav.="<a href='index.php?page=".($this->pageNow-1)."'> 上一页</a> "; <br>} <br>if ($this->pageNow!=1) <br>{ <br>$this->nav.="<a href='index.php?page=1'>首页</a> "; <br>} <br>for ($start=$step;$start<$step+10 && $start<=$this->pageCount;$start++) <br>{ <br>$this->nav.="<a href='index.php?page=".$start."'>".$start."</a> "; <br>} <br>if ($this->pageNow!=$this->pageCount) <br>{ <br>$this->nav.="<a href='index.php?page=".$this->pageCount."'>末页</a> "; <br>} <br>if ($this->pageNow!=$this->pageCount) <br>{ <br>$this->nav.=" <a href='index.php?page=".($this->pageNow+1)."'>下一页</a>"; <br>} <br>if ($this->pageCount>10 && $this->pageNow<$this->pageCount-8){ <br>$this->nav.=" <a href='index.php?page=".($step+10)."'> >> </a>";//整体每10页向后翻 <br>} <br>$this->nav.="/共有".$this->pageCount."页"; <br>} <br>} <br>?> <br> <br>由于zf中操作数据库的任务由model层来完成,所以,我将获取$rowCount的值的函数放在了对应的表model中 <br>比如:我是操作order表的 <br>那么当我要显示所有订单信息的时候,我通过order类中的showorder()方法取得$rowCount的值,并将其付给分页类中的$rowCount属性 <br>同样,将要显示在页面上的数据信息也一并付给了分页类中的$res_arr属性 <br>这样,我们就可以很容易的通过实例化一个分页类(fenyePage),然后将其通过参数传给showorder()函数,由该函数完成以下动作: <br>①要显示在页面上的信息 <br>②表中总共有多少条记录 <br><span><u></u></span> 代码如下:<pre class="brush:php;toolbar:false layui-box layui-code-view layui-code-notepad"><ol class="layui-code-ol"><li><br>/** <br>* 根据指定的用户id,查询该用户的历史订餐记录 <br>* <br>* @author 小飞 2012/5/30 <br>* @param $id 用户id <br>* @param $fenye 实例化的一个对象,用来处理分页 <br>* @todo $sql1语句 "select * from table where * limit 0,10" 该sql语句主要用来检索数据库中的数据,用以显示在view层 <br>* @todo $sql2语句 "select count(id) from table" 该sql语句用来得出总的数据量 <br>*/ <br>public function showorder($id=null,$fenye=null) <br>{ <br>$db = $this->getAdapter(); <br>$select=$db->select(); <br>$select->from(array('o' => 'order'),array('o.id','o.user_id','o.user_name','o.food_name','o.food_price','o.order_time','o.order_state')); <br>if ($id!=null){ <br>$select->where('o.user_id=?',$id); <br>} <br>$select->join(array('d'=>'department'),'o.dep_id = d.id','d.dep_name'); <br>if($fenye!=null){ <br>$select->limit($fenye->pageSize,($fenye->pageNow-1)*$fenye->pageSize); <br>} <br>$sql1=$select->__toString(); <br>//该sql语句主要用来计算总的数据量 <br>$sql2="SELECT COUNT(id) FROM `order`"; <br>$fenye->res_arr=$db->fetchAll($sql1);//将要显示的数据存储到分页类的$res_arr属性当中,方便调用 <br>$rowCount=$db->fetchAll($sql2);//将表中的总数据量保存到分页类的rowCount属性当中 <br>$fenye->rowCount=$rowCount[0]['COUNT(id)']; <br>$fenye->getLink(); <br>return $fenye->res_arr; <br>} <br> <br>至此,分页类的功能就已经实现了 <br>原创文章:WEB开发_小飞 <br></li><li> </li><li> </li></ol></pre></li></ol></pre>