PEAR探奇之PEAR::Pager

王朝other·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

在页面上显示大量数据,是WEB项目中很常见的一个作法,但限于屏幕的大小,为了便于用户阅读,我们通常需要将数据分页显示,所以分页功能是大部份项目不可缺少的。PEAR::Pager是一个功能强大的分页类,使用非常方便。

系统需求:PHP4.3.* /PHP5,PEAR::Pager

PEAR::Pager有两种分页显示模式,一是Jumping,二是Sliding。两者有什么区别,我们来看两个例子:

Jumping.php

<?php

require_once 'Pager/Pager.php';

$params = array(

'mode' => 'Jumping',

'perPage' => 3,

'delta' => 5,

'itemData' => array('a','b','c','d','e','z','ty','xc','fg','fg','jk','hj','ty','xc','e','z','ty','xc','fg','fg','jk','hj','ty','xc')

);

echo "<BR>当前分页模式:".$params['mode'];

echo "<BR>每页显示数据条数:".$params['perPage'];

echo "<BR>显示页数:".$params['delta'];

echo "<BR>详细数据数组:";

print_r($params['itemData']);

$pager = & Pager::factory($params);

$data = $pager->getPageData();

$links = $pager->getLinks();

echo "<P>最后效果:";

echo $links['all'];

echo $pager->linkTags;

echo '<P>当前页的数据: ' ;

echo "<pre>";

print_r($data);

echo "</pre>";

echo "其它类方法得到的数据:<P>";

echo 'getCurrentPageID()...: ';

var_dump($pager->getCurrentPageID());

echo "<BR>";

echo 'getNextPageID()......: ';

var_dump($pager->getNextPageID());

echo "<BR>";

echo 'getPreviousPageID()..: ';

var_dump($pager->getPreviousPageID());

echo "<BR>";

echo 'numItems()...........: ';

var_dump($pager->numItems());

echo "<BR>";

echo 'numPages()...........: ';

var_dump($pager->numPages());

echo "<BR>";

echo 'isFirstPage()........: ';

var_dump($pager->isFirstPage());

echo "<BR>";

echo 'isLastPage().........: ';

var_dump($pager->isLastPage());

echo "<BR>";

echo 'isLastPageComplete().: ';

var_dump($pager->isLastPageComplete());

echo "<BR>";

echo '$pager->range........: ';

var_dump($pager->range); echo "<BR>";

?>

运行结果如下图:

Sliding.php

<?php

require_once 'Pager/Pager.php';

$month = 'september';

$params = array(

'mode' => 'Sliding',

'append' => false,

'urlVar' => 'num',

'path' => 'http://localhost/' . $month,

'fileName' => 'art%d.html', //%d将被替换成当前页的数字

'itemData' => array('a','b','c','d','e','z','ty','xc','fg','fg','jk','hj','ty','xc','e','z','ty','xc','fg','fg','jk','hj','ty','xc'),

'perPage' => 3

);

echo "<BR>当前分页模式:".$params['mode'];

echo "<BR>每页显示数据条数:".$params['perPage'];

echo "<BR>链接指向路径:".$params['path'];

echo "<BR>链接指向文件名:".$params['fileName'];

echo "<BR>详细数据数组:";

print_r($params['itemData']);

$pager = & Pager::factory($params);

$data = $pager->getPageData();

echo "<P>最后效果:";

echo $pager->links;

echo '<P>当前页的数据: ' ;

echo "<pre>";

echo 'Data for current page: '; print_r($data);

echo "</pre>";

echo "其它类方法得到的数据:<P>";

echo 'getCurrentPageID()...: ';

var_dump($pager->getCurrentPageID());

echo "<BR>";

echo 'getNextPageID()......: ';

var_dump($pager->getNextPageID());

echo "<BR>";

echo 'getPreviousPageID()..: ';

var_dump($pager->getPreviousPageID());

echo "<BR>";

echo 'numItems()...........: ';

var_dump($pager->numItems());

echo "<BR>";

echo 'numPages()...........: ';

var_dump($pager->numPages());

echo "<BR>";

echo 'isFirstPage()........: ';

var_dump($pager->isFirstPage());

echo "<BR>";

echo 'isLastPage().........: ';

var_dump($pager->isLastPage());

echo "<BR>";

echo 'isLastPageComplete().: ';

var_dump($pager->isLastPageComplete());

echo "<BR>";

echo '$pager->range........: ';

var_dump($pager->range); echo "<BR>";

?>

运行结果如下图:

运行以上代码,可以发现,Jumping是跳跃式前进,一次翻几页,而Sliding是逐页地前进。

在例子中可以看到PEAR::Pager提供了很多类方法,可以返回我们所需要的数据,如当前页ID,下一页ID,当前页上数据条数等等。

下面将所有类方法的作用列出,供参考:

Pager::Pager() – 构造函数参数为二维数组详见上面的示例

Pager::factory() --建立一个Pager对象

Pager::getCurrentPageID() 返回当前页的ID

Pager::getLinks() 返回某个页所对应的链接 参数为页面的ID 参数为空则返回当前页的链接

Pager::getNextPageID() 返回下一页的ID

Pager::getOffsetByPageId() 返回记录范围

例如当前页为1,每页显示10条,则返回(1,10)

如当前页为2,每页显示8条,则返回(8,16)

Pager::getPageData() 以数组形式返回当前页数据

Pager::getPageIdByOffset() 根据记录范围返回页面ID

本方法仅当分页模式为Jumping时有效

Pager::getPageRangeByPageId() 返回某个页面所在的记录范围

例如模式为Jumping时,如果pageId=3 , delta=10,则返回(1,10),如果pageId=3 , delta=10,则仍然返回(1,10),因为1,3都在10的范围之内。如果pageId =14,则返回(10,20),

因为14落于10,20之间。

Pager::getPreviousPageID() 得到前一页的ID

Pager::getperpageselectbox() 返回一个XHTML的Select标签字符串

[1] [2] 下一页

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航