-
-
$nav='';//用来保存页数的一个变量
- for ($i=1;$i{
- $nav.="第".$i."页 ";
- }
复制代码
以上的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{
- $nav.="第".$i."页 ";
- }
复制代码
比如,当前页面$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语句的函数就能得到
由于zf中操作数据库的任务由model层来完成,所以,我将获取$rowCount的值的函数放在了对应的表model中
比如:我是操作order表的
那么当我要显示所有订单信息的时候,我通过order类中的showorder()方法取得$rowCount的值,并将其付给分页类中的$rowCount属性
同样,将要显示在页面上的数据信息也一并付给了分页类中的$res_arr属性
这样,我们就可以很容易的通过实例化一个分页类(fenyePage),然后将其通过参数传给showorder()函数,由该函数完成以下动作:
①要显示在页面上的信息
②表中总共有多少条记录
-
-
/**
- * 根据指定的用户id,查询该用户的历史订餐记录
- *
- * @author 小飞 2012/5/30
- * @param $id 用户id
- * @param $fenye 实例化的一个对象,用来处理分页
- * @todo $sql1语句 "select * from table where * limit 0,10" 该sql语句主要用来检索数据库中的数据,用以显示在view层
- * @todo $sql2语句 "select count(id) from table" 该sql语句用来得出总的数据量
- * @link http://bbs.it-home.org
- */
- public function showorder($id=null,$fenye=null)
- {
- $db = $this->getAdapter();
- $select=$db->select();
- $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'));
- if ($id!=null){
- $select->where('o.user_id=?',$id);
- }
- $select->join(array('d'=>'department'),'o.dep_id = d.id','d.dep_name');
- if($fenye!=null){
- $select->limit($fenye->pageSize,($fenye->pageNow-1)*$fenye->pageSize);
- }
- $sql1=$select->__toString();
- //该sql语句主要用来计算总的数据量
- $sql2="SELECT COUNT(id) FROM `order`";
- $fenye->res_arr=$db->fetchAll($sql1);//将要显示的数据存储到分页类的$res_arr属性当中,方便调用
- $rowCount=$db->fetchAll($sql2);//将表中的总数据量保存到分页类的rowCount属性当中
- $fenye->rowCount=$rowCount[0]['COUNT(id)'];
- $fenye->getLink();
- return $fenye->res_arr
- }
复制代码
|