zentaoPHP框架的分页解决方案

2009-12-01 21:22:22
王春生
23979
最后编辑:grxiyy 于 2017-02-08 15:30:52
简介:zentaoPHP提供的分页解决方案。

分页对于基于数据库的应用来讲,是很常见的一个问题。新的zentaoPHP框架中,提供了内置的分页功能。使用如下:

我们以查询用户列表为例,在应用中建立一个user的模块,在其中的control文件中,定义一个browse方法,来完成分页的功能:

一、browse方法关于分页的三个参数

browse方法需要定义三个参数:recTotal, recPerPage, pageID,变量名是固定的。

public function browse($recTotal, $recPerPage, $pageID)
{
    /* 加载分页类,并生成pager对象。*/
    $this->app->loadClass('pager', $static = true);
    $pager = new pager($recTotal, $recPerPage, $pageID);

    /* 将分页类传给model,进行分页。*/
    $users = $this->user->getList($pager);
}

二、model方法中调用pager对象

model中定义一个getList方法,接收pager对象,并在dao查询的时候,调用pager($pager)方法来生成分页语句。

public function getList($pager)
{
    return $this->dao->select(*)->from('user')->page($pager)->fetchAll();
}

三、control中将pager对象赋值给模板

再回到control的browse方法中,将pager对象赋值给模板。

public function browse($recTotal, $recPerPage, $pageID)
{
    /* 加载分页类,并生成pager对象。*/
    $this->app->loadClass('pager', $static = true);
    $pager = new pager($recTotal, $recPerPage, $pageID);

    /* 将分页类传给model,进行分页。*/
    $users = $this->user->getList($pager);
    
    /* 赋值到模板。*/
    $this->view->users = $users;
    $this->view->pager = $pager;
}

模板中显示分页链接:show()方法有两个参数,$align: left, center, right,默认是居右对齐。$type: full|short|shortest

<?php $pager->show();?>

评论列表
小码农 2018-06-26 14:43:46
春哥,怎么在同一个模块下,实现两种不同的搜索,$config->模块名->search['fields'],这种一个模块是不是只能用一个条件搜索
王春生 2018-06-28 09:01:02
不明白你说的两种不同的搜索是啥意思。但肯定是可以的。:)
分页 2018-04-02 16:27:50
当前页面加一些搜索条件,如何展示分页。
xixi 2017-11-14 11:13:00
搜索条件过多,需要多次查询数据库,将多次查询的结果处理后返回到control,这种情况该如何实现分页
qq 2017-11-14 10:53:13
内置分页用不了,将自己查询到的数量,如何传给分页对象
王春生 2017-11-14 14:16:46
分页对象初始化的时候可以设置。看一下lib/base/pager.class.php
小鱼 2017-09-20 18:56:49
春哥,请教个问题。query 调用如何分页 ? $this->dao->query($sql)
王春生 2017-09-21 08:18:36
我们内置的分页用不上的话,要自己来查询数量,然后再传参给分页类了。
Nisedt 2017-08-19 21:12:41
我想在一个页面做两个可以动态刷新的表格分页可以实现吗?
王春生 2017-08-21 08:48:29
当然可以。
hison 2017-05-21 14:41:24
含有子查询的sql,如何实现分页功能
王春生 2017-05-22 08:17:28
太复杂的sql查询会有问题。建议分开检索。将子查询的结果可以放在session或者传参。
wdl 2016-09-19 18:06:04
怎么处理有搜索的分页?
王春生 2016-09-22 08:00:33
参考我们禅道的里面的实现。
刘先生 2016-08-05 15:25:46
分组以后没法分页了
幽你一默 2016-03-11 11:05:57
我刚才测试了下,发现上面讲解的代码中,model的return $this->dao->select(*)->from('user')->page($pager)->fetchAll();这行代码中的select(*)星号得加引号才好使。。
王春生 2016-03-11 16:03:54
嗯。要加星号。
1/2
发表评论
评论通过审核后显示。