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


Posted in PHP onMay 30, 2012

只需要得到两个变量就成功了一半:
每页要显示的记录数$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."页"; 
} 
} 
?>

由于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语句用来得出总的数据量 
*/ 
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; 
}

至此,分页类的功能就已经实现了
原创文章:WEB开发_小飞
PHP 相关文章推荐
PHP脚本的10个技巧(8)
Oct 09 PHP
phpfans留言版用到的数据操作类和分页类
Jan 04 PHP
PHPnow安装服务[apache_pn]失败的问题的解决方法
Sep 10 PHP
php购物车实现代码
Oct 10 PHP
PHP __autoload函数(自动载入类文件)的使用方法
Feb 04 PHP
探讨PHP使用eAccelerator的API开发详解
Jun 09 PHP
thinkPHP订单数字提醒功能的实现方法
Dec 01 PHP
postman的安装与使用方法(模拟Get和Post请求)
Aug 06 PHP
tp5(thinkPHP5)框架实现多数据库查询的方法
Jan 10 PHP
浅谈laravel 5.6 安装 windows上使用composer的安装过程
Oct 18 PHP
php-7.3.6 编译安装过程
Feb 11 PHP
PHP $O00OO0=urldecode &amp; eval 解密,记一次商业源码的去后门
Sep 13 PHP
php DOS攻击实现代码(附如何防范)
May 29 #PHP
PHP fgetcsv 定义和用法(附windows与linux下兼容问题)
May 29 #PHP
PHP中将网页导出为Word文档的代码
May 25 #PHP
php在文件指定行中写入代码的方法
May 23 #PHP
php替换超长文本中的特殊字符的函数代码
May 22 #PHP
php提示undefined index的几种解决方法
May 21 #PHP
openflashchart 2.0 简单案例php版
May 21 #PHP
You might like
PHP音乐采集(部分代码)
2007/02/14 PHP
Laravel中使用自己编写类库的3种方法
2015/02/10 PHP
PHP递归实现层级树状展开
2016/04/01 PHP
Thinkphp框架中D方法与M方法的区别
2016/12/23 PHP
浅谈PHP中的错误处理和异常处理
2017/02/04 PHP
Yii2框架视图(View)操作及Layout的使用方法分析
2019/05/27 PHP
laravel orm 关联条件查询代码
2019/10/21 PHP
TP5框架model常见操作示例小结【增删改查、聚合、时间戳、软删除等】
2020/04/05 PHP
Javascript与flash交互通信基础教程
2008/08/07 Javascript
javascript 面向对象全新理练之原型继承
2009/12/03 Javascript
动态创建样式表在各浏览器中的差异测试代码
2011/09/13 Javascript
对jQuery的事件绑定的一些思考(补充)
2013/04/20 Javascript
JavaScript访问CSS属性的几种方式介绍
2014/07/21 Javascript
jQuery中的编程范式详解
2014/12/15 Javascript
JavaScript实现添加及删除事件的方法小结
2015/08/04 Javascript
简述jQuery ajax的执行顺序
2016/01/05 Javascript
jQuery Ajax向服务端传递数组参数值的实例代码
2017/09/03 jQuery
微信小程序 功能函数小结(手机号验证*、密码验证*、获取验证码*)
2017/12/08 Javascript
vue插件实现v-model功能
2018/09/10 Javascript
详解VUE里子组件如何获取父组件动态变化的值
2018/12/26 Javascript
angular 服务随记小结
2019/05/06 Javascript
VUE的history模式下除了index外其他路由404报错解决办法
2019/08/21 Javascript
Vue移动端项目实现使用手机预览调试操作
2020/07/18 Javascript
[46:55]Ti4 冒泡赛第二轮 LGD vs C9
2014/07/14 DOTA
[46:25]DOTA2上海特级锦标赛主赛事日 - 4 败者组第五轮 MVP.Phx VS EG第二局
2016/03/05 DOTA
Python+django实现文件下载
2016/01/17 Python
Python爬豆瓣电影实例
2018/02/23 Python
Python和Go语言的区别总结
2019/02/20 Python
详解Python字符串切片
2019/05/20 Python
Python通过两个dataframe用for循环求笛卡尔积
2020/04/29 Python
使用CSS3 制作一个material-design 风格登录界面实例
2016/12/12 HTML / CSS
家乐福巴西网上超市:Carrefour巴西
2016/10/31 全球购物
英文简历中的自荐信范文
2013/12/14 职场文书
幼儿园秋游活动方案
2014/01/21 职场文书
2015年父亲节寄语
2015/03/23 职场文书
公司档案管理制度
2015/08/05 职场文书