}
if ( $this-numPages1 )
{
if ( !$this-isLastPage ) { $this-NextPageID = $this-CurrentPageID + 1; }
if ( !$this-isFirstPage ) { $this-PreviousPageID = $this-CurrentPageID - 1; }
}
return true;
}
/***
*
* 返回结果集的数据库连接
* 在结果集比较大的时候可以直接使用这个方法获得数据库连接,然后在类之外遍历,这样开销较小
* 如果结果集不是很大,可以直接使用getPageData的方式获取二维数组格式的结果
* getPageData方法也是调用本方法来获取结果的
*
***/
function getDataLink()
{
if ( $this-numItems )
{
global $db;
$PageID = $this-CurrentPageID;
$from = ($PageID - 1)*$this-PageSize;
$count = $this-PageSize;
$link = $db-limitQuery($this-sql, $from, $count);//使用Pear DB::limitQuery方法保证数据库兼容性
return $link;
}
else
{
return false;
}
}
/***
*
* 以二维数组的格式返回结果集
*
***/
function getPageData()
{
if ( $this-numItems )
{
if ( $res = $this-getDataLink() )
{
if ( $res-numRows() )
{
while ( $row = $res-fetchRow() )
{
$result[] = $row;
}
}
else
{
$result = array();
}
return $result;
}
else
{
return false;
}
}
else
{
return false;
}
}
function _setOptions($option)
{
$allow_options = array(
'PageSize',
'CurrentPageID',
'sql',
'numItems'
);
foreach ( $option as $key = $value )
{
if ( in_array($key, $allow_options)($value != null) )
{
$this-$key = $value;
}
}
return true;
}
}
?
?php
// FileName: test_pager.php
// 这是一段简单的示例代码,前边省略了使用pear db类建立数据库连接的代码
require "Pager.class.php";
if ( isset($_GET['page']) )
{
$page = (int)$_GET['page'];
}
else
{
$page = 1;
}
$sql = "select * from table order by id";
$pager_option = array(
"sql" = $sql,
"PageSize" = 10,
"CurrentPageID" = $page
);
if ( isset($_GET['numItems']) )
{
$pager_option['numItems'] = (int)$_GET['numItems'];
}
$pager = @new Pager($pager_option);
$data = https://www.04ip.com/post/$pager-getPageData();
if ( $pager-isFirstPage )
{
$turnover = "首页|上一页|";
}
else
{
$turnover = "a href='https://www.04ip.com/post/?page=1numItems=".$pager-numItems."'首页/a|a href="https://www.04ip.com/?page=".$pager-PreviousPageID."numItems=".$pager-numItems."'上一页/a|";
}
if ( $pager-isLastPage )
{
$turnover .= "下一页|尾页";
}
else
{
$turnover .= "a href="https://www.04ip.com/?page=".$pager-NextPageID."numItems=".$pager-numItems."'下一页/a|a href="https://www.04ip.com/?page=".$pager-numPages."numItems=".$pager-numItems."'尾页/a";
}
?
需要说明的地方有两个:
这个类仅仅处理数据 , 并不负责处理显示,因为我觉得将数据的处理和结果的显示都放到一个类里边实在是有些勉强 。显示的时候情况和要求多变,不如自己根据类给出的结果处理 , 更好的方法是根据这个Pager类继承一个自己的子类来显示不同的分页 , 比如显示用户分页列表可以:
?php
Class MemberPager extends Pager
{
function showMemberList()
{
global $db;
$data = https://www.04ip.com/post/$this-getPageData();
// 显示结果的代码
// ......
}
}
/// 调用
推荐阅读
- 启动系统自带虚拟机好吗,启动系统自带虚拟机好吗安全吗
- 苹果号能不能转移安卓手机,苹果手机能不能电话转移
- 在线观看html5,在线观看斗罗大陆免费全集高清
- 线下棋牌室游戏有哪些项目,线上线下棋牌类牌照
- mysql路径怎么查看 查看mysql数据文件路径
- C语言教学系统设计开题报告,c语言课题设计总结
- 苹果入门机和安卓旗舰机,苹果机子好还是安卓机子好
- 分布式爬虫ip,分布式爬虫技术
- go语言队列 golang消息队列