0

0

php分页 PHP分页显示制作详细讲解

PHP中文网

PHP中文网

发布时间:2017-03-16 15:49:34

|

2304人浏览过

|

来源于php中文网

原创

1、前言 

分页显示是一种非常常见的浏览和显示大量数据的方法,属于web编程中最常处理的事件之一。对于web编程的老手来说,编写这种代码实在是和呼吸一样自然,但是对于初学者来说,常常对这个问题摸不着头绪,因此特地撰写此文对这个问题进行详细的讲解,力求让看完这篇文章的朋友在看完以后对于分页显示的原理和实现方法有所了解。本文适合初学者阅读,所有示例代码均使用php编写。 

2、原理 

所谓分页显示,也就是将数据库中的结果集人为的分成一段一段的来显示,这里需要两个初始的参数: 

每页多少条记录($PageSize)? 

立即学习PHP免费学习笔记(深入)”;

当前是第几页($CurrentPageID)? 

现在只要再给我一个结果集,我就可以显示某段特定的结果出来。 

至于其他的参数,比如:上一页($PreviousPageID)、下一页($NextPageID)、总页数($numPages)等等,都可以根据前边这几个东西得到。 

以mysql数据库为例,如果要从表内截取某段内容,sql语句可以用:select * from table limit offset, rows。看看下面一组sql语句,尝试一下发现其中的规率。 

前10条记录:select * from table limit 0,10 

第11至20条记录:select * from table limit 10,10 

第21至30条记录:select * from table limit 20,10 

…… 

这一组sql语句其实就是当$PageSize=10的时候取表内每一页数据的sql语句,我们可以总结出这样一个模板: 

select * from table limit ($CurrentPageID - 1) * $PageSize, $PageSize 

拿这个模板代入对应的值和上边那一组sql语句对照一下看看是不是那么回事。搞定了最重要的如何获取数据的问题以后,剩下的就仅仅是传递参数,构造合适的sql语句然后使用php从数据库内获取数据并显示了。以下我将用具体代码加以说明。 

3、简单代码 

动力先锋仿阿里巴巴B2B电子商务系统
动力先锋仿阿里巴巴B2B电子商务系统

前台功能介绍:1、网页首页显示有高级会员推荐,精品推荐,商业机会分类列表,最新供求信息,网站动态,推荐企业,行业动态等;2、商业机会栏目功能有:二级分类,已经带有详细分类的数据库,后台可以更改增加操作,并可以推荐公司,栏目分为分类显示信息,最新的采购、供应、合作和代理信息,搜索时同样按分类,信息,时间,交易类型等搜索;3、展厅展品栏目功能:二级分类,已经带有详细分类的数据库,后台可以更改增加操作,

下载

请详细阅读以下代码,自己调试运行一次,最好把它修改一次,加上自己的功能,比如搜索等等。 

第一页|上一页|'; 
} 
if( ($page == $page_count) || ($page_count == 0) ){ 
$page_string .= '下一页|尾页'; 
} 
else{ 
$page_string .= '下一页|尾页'; 
} 
// 获取数据,以二维数组格式返回结果 
if( $amount ){ 
$sql = "select * from table order by id desc limit ". ($page-1)*$page_size .", $page_size"; 
$result = mysql_query($sql); 
while ( $row = mysql_fetch_row($result) ){ 
$rowset[] = $row; 
} 
}else{ 
$rowset = array(); 
} 
// 没有包含显示结果的代码,那不在讨论范围,只要用foreach就可以很简单的用得到的二维数组来显示结果 
?>

4、OO风格代码 

以下代码中的数据库连接是使用的pear db类进行处理 

_setOptions($option); 
// 总条数 
if ( !isset($this->numItems) ) 
{ 
$res = $db->query($this->sql); 
$this->numItems = $res->numRows(); 
} 
// 总页数 
if ( $this->numItems > 0 ) 
{ 
if ( $this->numItems < $this->PageSize ){ $this->numPages = 1; } 
if ( $this->numItems % $this->PageSize ) 
{ 
$this->numPages= (int)($this->numItems / $this->PageSize) + 1; 
} 
else 
{ 
$this->numPages = $this->numItems / $this->PageSize; 
} 
} 
else 
{ 
$this->numPages = 0; 
} 
switch ( $this->CurrentPageID ) 
{ 
case $this->numPages == 1: 
$this->isFirstPage = true; 
$this->isLastPage = true; 
break; 
case 1: 
$this->isFirstPage = true; 
$this->isLastPage = false; 
break; 
case $this->numPages: 
$this->isFirstPage = false; 
$this->isLastPage = true; 
break; 
default: 
$this->isFirstPage = false; 
$this->isLastPage = false; 
} 
if ( $this->numPages > 1 ) 
{ 
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; 
} 
} 
?> 
 $sql, 
"PageSize" => 10, 
"CurrentPageID" => $page 
); 
if ( isset($_GET['numItems']) ) 
{ 
$pager_option['numItems'] = (int)$_GET['numItems']; 
} 
$pager = @new Pager($pager_option); 
$data = $pager->getPageData(); 
if ( $pager->isFirstPage ) 
{ 
$turnover = "首页|上一页|"; 
} 
else 
{ 
$turnover = "首页|上一页|"; 
} 
if ( $pager->isLastPage ) 
{ 
$turnover .= "下一页|尾页"; 
} 
else 
{ 
$turnover .= "下一页|尾页"; 
} 
?>

需要说明的地方有两个: 

这个类仅仅处理数据,并不负责处理显示,因为我觉得将数据的处理和结果的显示都放到一个类里边实在是有些勉强。显示的时候情况和要求多变,不如自己根据类给出的结果处理,更好的方法是根据这个Pager类继承一个自己的子类来显示不同的分页,比如显示用户分页列表可以: 

getPageData(); 
// 显示结果的代码 
// ...... 
} 
} 
/// 调用 
if ( isset($_GET['page']) ) 
{ 
$page = (int)$_GET['page']; 
} 
else 
{ 
$page = 1; 
} 
$sql = "select * from members order by id"; 
$pager_option = array( 
"sql" => $sql, 
"PageSize" => 10, 
"CurrentPageID" => $page 
); 
if ( isset($_GET['numItems']) ) 
{ 
$pager_option['numItems'] = (int)$_GET['numItems']; 
} 
$pager = @new MemberPager($pager_option); 
$pager->showMemberList(); 
?>

第二个需要说明的地方就是不同数据库的兼容性,在不同的数据库里截获一段结果的写法是不一样的。 

mysql: select * from table limit offset, rows 

pgsql: select * from table limit m offset n 

...... 

所以要在类里边获取结果的时候需要使用pear db类的limitQuery方法。 

ok,写完收功,希望花时间看完这些文字的你不觉得是浪费了时间。 

以上就介绍了php分页 PHP分页显示制作详细讲解,包括了php分页方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

相关文章:

使用PHP实现简单分页类及其详细的使用方法

php分页类代码

php 分页原理详解

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

57

2026.01.23

c++空格相关教程合集
c++空格相关教程合集

本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

57

2026.01.23

yy漫画官方登录入口地址合集
yy漫画官方登录入口地址合集

本专题整合了yy漫画入口相关合集,阅读专题下面的文章了解更多详细内容。

237

2026.01.23

漫蛙最新入口地址汇总2026
漫蛙最新入口地址汇总2026

本专题整合了漫蛙最新入口地址大全,阅读专题下面的文章了解更多详细内容。

393

2026.01.23

C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

17

2026.01.23

php远程文件教程合集
php远程文件教程合集

本专题整合了php远程文件相关教程,阅读专题下面的文章了解更多详细内容。

103

2026.01.22

PHP后端开发相关内容汇总
PHP后端开发相关内容汇总

本专题整合了PHP后端开发相关内容,阅读专题下面的文章了解更多详细内容。

73

2026.01.22

php会话教程合集
php会话教程合集

本专题整合了php会话教程相关合集,阅读专题下面的文章了解更多详细内容。

81

2026.01.22

宝塔PHP8.4相关教程汇总
宝塔PHP8.4相关教程汇总

本专题整合了宝塔PHP8.4相关教程,阅读专题下面的文章了解更多详细内容。

70

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
CSS3 教程
CSS3 教程

共18课时 | 4.9万人学习

php-src源码分析探索
php-src源码分析探索

共6课时 | 0.5万人学习

PHP自制框架
PHP自制框架

共8课时 | 0.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号