fleaphp常用方法分页之Pager使用方法
前端之家收集整理的这篇文章主要介绍了
fleaphp常用方法分页之Pager使用方法,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
Pager 分页函数
<div class="codetitle"><a style="CURSOR: pointer" data="53242" class="copybut" id="copybut53242" onclick="doCopy('code53242')"> 代码如下:
<div class="codebody" id="code53242">
/*
构造
函数
如果 $source 参数是一个 TableDataGateway 对象,则 FLEA_Helper_Pager 会
调用 该 TDG 对象的 findCount() 和 findAll() 来确定记录总数并返回记录集。
如果 $source 参数是一个字符串,则假定为 sql 语句。这时,FLEA_Helper_Pager
不会
自动调用计算各项
分页参数。必须通过 setCount()
方法来设置作为
分页计算
基础的记录总数。
同时,如果 $source 参数为一个字符串,则不需要 $conditions 和 $sortby 参数。
而且可以通过 setDBO()
方法设置要使用的
数据库访问对象。否则 FLEA_Helper_Pager
将尝试获取一个默认的数据库访问对象。
@param TableDataGateway|string $source
@param int $currentPage
@param int $pageSize
@param mixed $conditions
@param string $sortby
@param int $basePageIndex
@return FLEA_Helper_Pager
/
function FLEA_Helper_Pager(& $source,$currentPage,$pageSize = 20,$conditions = null,$sortby = null,$basePageIndex = 0)
{
$this->_basePageIndex = $basePageIndex;
$this->_currentPage = $this->currentPage = $currentPage;
$this->pageSize = $pageSize;
if (is_object($source)) {
$this->source =& $source;
$this->_conditions = $conditions;
$this->_sortby = $sortby;
$this->totalCount = $this->count = (int)$this->source->findCount($conditions);
$this->computingPage();
} elseif (!empty($source)) {
$this->source = $source;
$sql = "SELECT COUNT() FROM ( $source ) as _count_table";
$this->dbo =& FLEA::getDBO();
$this->totalCount = $this->count = (int)$this->dbo->getOne($
sql);
$this->computingPage();
}
}
Pager 参数说明
$source
数据库操作类
$currentPage 当前页
$pageSize 每页
显示记录
数量 $conditions
查询条件
$sortby 排序方式
$basePageIndex
页码基数
Pager 使用示例(实例)
<div class="codetitle">
<a style="CURSOR: pointer" data="44956" class="copybut" id="copybut44956" onclick="doCopy('code44956')"> 代码如下: <div class="codebody" id="code44956">
$dirname = dirname(
FILE);
define('APP_DIR',$dirname . '/APP');
define('NO_LEGACY_FLEA
PHP',true);
require($dirname.'/Flea
PHP/FLEA/FLEA.
PHP');
//设置缓存目录
FLEA::setAppInf('internalCacheDir',$dirname.'/_Cache');
//
链接数据库 $dsn = array(
'driver' => '
MysqL',
'host' => 'localhost',
'login' => 'root',
'password' => '',
'database' => '
wordpress'
);
FLEA::setAppInf('dbDSN',$dsn);
//读取wp_posts的
内容 FLEA::loadClass('FLEA_Db_TableDataGateway');
FLEA::loadClass('FLEA_Helper_Pager');
//FLEA::loadHelper('pager');
class Teble_Class extends FLEA_Db_TableDataGateway {
var $tableName = 'wp_posts';
var $primaryKey = 'ID';
}
$tableposts =& new Teble_Class();
$pager =& new FLEA_Helper_Pager($tableposts,2,5);
$page = $pager->getPagerData();
print_r($page);
getPagerData 返回一些数据供
调用 <div class="codetitle">
<a style="CURSOR: pointer" data="22929" class="copybut" id="copybut22929" onclick="doCopy('code22929')"> 代码如下: <div class="codebody" id="code22929">
$data = array(
'pageSize' => $this->pageSize,
'totalCount' => $this->totalCount,
'count' => $this->count,
'pageCount' => $this->pageCount,
'firstPage' => $this->firstPage,
'firstPageNumber' => $this->firstPageNumber,
'lastPage' => $this->lastPage,
'lastPageNumber' => $this->lastPageNumber,
'prevPage' => $this->prevPage,
'prevPageNumber' => $this->prevPageNumber,
'nextPage' => $this->nextPage,
'nextPageNumber' => $this->nextPageNumber,
'currentPage' => $this->currentPage,
'currentPageNumber' => $this->currentPageNumber,
);