您好,欢迎访问一九零五行业门户网

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

php分页思路以及在zf中的使用,需要的朋友可以参考下
只需要得到两个变量就成功了一半:
每页要显示的记录数$pagesize
表中总的数据量 $rowcount
有了以上两个变量,我们就可以得出 共有几页了$pagecount
然后通过for循环,比如总共有13个页面,那么很容易就能通过for循环输出页数
代码如下:
$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语句的函数就能得到
代码如下:
程序员指定的
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.= ;//整体每10页向前翻
}
if ($this->pagenow!=1)
{
$this->nav.=pagenow-1).%22> 上一页 ;
}
if ($this->pagenow!=1)
{
$this->nav.=首页 ;
}
for ($start=$step;$startpagecount;$start++)
{
$this->nav.=.$start. ;
}
if ($this->pagenow!=$this->pagecount)
{
$this->nav.=pagecount.%22>末页 ;
}
if ($this->pagenow!=$this->pagecount)
{
$this->nav.= pagenow+1).%22>下一页;
}
if ($this->pagecount>10 && $this->pagenowpagecount-8){
$this->nav.= >> ;//整体每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开发_小飞
其它类似信息

推荐信息