0

0

PHP如何实现分页功能_数据分页显示完整教程

絕刀狂花

絕刀狂花

发布时间:2025-09-21 19:20:01

|

793人浏览过

|

来源于php中文网

原创

答案:PHP分页需安全获取页码和每页数量,通过验证、过滤用户输入防止注入;计算总页数用ceil(总记录数/每页数量),并处理空数据集;生成导航链接时采用范围显示、高亮当前页,并添加rel="prev/next"提升SEO。

php如何实现分页功能_数据分页显示完整教程

PHP实现分页功能,本质上就是从数据库中分批次地取出数据,然后在前端页面上通过导航链接进行切换显示。这通常涉及到SQL的

LIMIT
子句来控制查询范围,同时需要计算总页数、当前页码,并动态生成“上一页”、“下一页”以及具体的页码链接。它是个经典且实用的功能,几乎所有需要展示大量列表数据的场景都离不开它。

解决方案

要实现一个健壮的PHP分页功能,我们通常需要以下几个核心步骤:确定每页显示数量、获取当前页码、查询总记录数、计算总页数、根据当前页码查询对应数据,最后是生成分页导航链接。

setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
} catch(PDOException $e) {
    echo "数据库连接失败: " . $e->getMessage();
    exit();
}

// 2. 配置参数
$records_per_page = 10; // 每页显示10条记录

// 3. 获取当前页码
// 确保页码是有效的整数,并设置默认值
$current_page = isset($_GET['page']) ? (int)$_GET['page'] : 1;
if ($current_page < 1) {
    $current_page = 1;
}

// 4. 查询总记录数
$total_records_query = $conn->query("SELECT COUNT(*) FROM articles");
$total_records = $total_records_query->fetchColumn();

// 5. 计算总页数
$total_pages = ceil($total_records / $records_per_page);

// 确保当前页码不超过总页数(如果总记录数为空,总页数为0,也应该将当前页码设为1)
if ($total_pages > 0 && $current_page > $total_pages) {
    $current_page = $total_pages;
} elseif ($total_pages == 0) { // 如果没有数据
    $current_page = 1;
}

// 6. 计算查询的偏移量 (OFFSET)
$offset = ($current_page - 1) * $records_per_page;

// 7. 查询当前页的数据
$stmt = $conn->prepare("SELECT id, title, content FROM articles ORDER BY id DESC LIMIT :offset, :limit");
$stmt->bindParam(':offset', $offset, PDO::PARAM_INT);
$stmt->bindParam(':limit', $records_per_page, PDO::PARAM_INT);
$stmt->execute();
$articles = $stmt->fetchAll(PDO::FETCH_ASSOC);

// 8. 显示数据
echo "

文章列表

"; if (!empty($articles)) { foreach ($articles as $article) { echo "
"; echo "

" . htmlspecialchars($article['title']) . "

"; echo "

" . nl2br(htmlspecialchars(substr($article['content'], 0, 150))) . "...

"; echo "阅读更多"; echo "

"; } } else { echo "

暂无文章。

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

"; } // 9. 生成分页导航 echo ""; $conn = null; // 关闭数据库连接 ?>

PHP分页中如何安全有效地获取当前页码和限制每页显示数量?

在分页功能里,当前页码(

page
)和每页显示数量(
LIMIT
records_per_page
)通常都是通过URL参数传递的,比如
?page=2&limit=20
。这里面就藏着潜在的安全隐患和逻辑错误。我个人的经验是,对待任何用户输入都得小心翼翼,哪怕只是一个数字。

首先,从

$_GET
超全局变量获取这些值是常规操作。但直接拿来用是万万不可的。比如,如果用户把
page
参数改成
page=abc
或者
page=-5
,甚至
page=1;DROP TABLE users;
,那你的程序就可能出错了,甚至被攻击。所以,最关键的一步是输入验证和净化

我通常会这么处理:

  1. 类型转换与默认值:使用
    isset()
    检查参数是否存在,然后用
    (int)
    强制转换为整数类型。如果不存在,或者转换后不是一个正整数,就给它一个合理的默认值。比如,
    $current_page = isset($_GET['page']) ? (int)$_GET['page'] : 1;
  2. 范围检查:确保页码不会小于1。
    if ($current_page < 1) { $current_page = 1; }
    。对于
    records_per_page
    ,你可能还需要限制它的上限和下限,防止用户设置一个过大或过小的数值,影响性能或页面布局。例如,
    $records_per_page = isset($_GET['limit']) ? (int)$_GET['limit'] : 10; if ($records_per_page < 1 || $records_per_page > 100) { $records_per_page = 10; }
  3. 避免SQL注入:虽然这里主要是整数,看起来风险不大,但养成使用预处理语句的好习惯至关重要。将
    $offset
    $records_per_page
    作为参数绑定到SQL语句中(如PDO的
    bindParam
    ),而不是直接拼接字符串,这样可以彻底杜绝这类注入风险。即使是
    LIMIT
    子句,虽然通常认为它对注入的防御性较好,但防患于未然总是没错的。

通过这些步骤,我们就能确保获取到的页码和每页显示数量是程序可以安全处理的有效整数,避免了因为恶意或无效输入导致的问题。

实现数据分页时,如何准确计算总页数并处理空数据集的情况?

准确计算总页数是分页逻辑的核心,它决定了你的分页导航有多少个链接。而处理空数据集,则是让程序在没有数据时也能优雅地运行,而不是抛出错误或显示奇怪的界面。

计算总页数,通常是先获取总记录数,然后用一个简单的数学公式来完成。

  1. 获取总记录数:这是最直接的方式。执行一个

    SELECT COUNT(*) FROM your_table
    的SQL查询。这个查询会返回一个整数,就是你的数据表里符合条件的总条目数。注意,如果你在主查询中使用了
    WHERE
    子句,那么在
    COUNT(*)
    查询中也要包含相同的
    WHERE
    子句,否则计算出的总记录数就不准确了。

    SELECT COUNT(*) FROM articles WHERE category_id = 1;

    而不是:

    SELECT COUNT(*) FROM articles;

    当然,如果你的分页是针对所有数据的,那就不需要

    WHERE
    了。

  2. 计算总页数:有了总记录数(

    $total_records
    )和每页显示数量(
    $records_per_page
    ),总页数(
    $total_pages
    )的计算公式是:

    $total_pages = ceil($total_records / $records_per_page);

    这里的

    ceil()
    函数(向上取整)非常关键。比如,如果有103条记录,每页显示10条,那么
    103 / 10 = 10.3
    。如果直接取整得到10页,那么最后3条数据就显示不出来了。
    ceil(10.3)
    会得到11,这意味着需要11页来完整显示所有数据。

  3. 处理空数据集

    ChuangxinCMS企业网站管理系统1.0
    ChuangxinCMS企业网站管理系统1.0

    欢迎使用ChuangxinCMS企业网站管理系统软件! ChuangxinCMS是一个采用PHP技术和MYSQL数据库开发的企业网站管理系统,使用ChuangxinCMS能在最短的时间内花费最少的成本来搭建一个功能完善的企业网站,ChuangxinCMS具有一系列完善的内容管理功能,包括文章发布、分类管理、产品发布展示、下载模块等,整个系统页面设计简洁大方,功能实用高效,是中小型企业建站的最佳选择

    下载
    • $total_records
      为0时,
      $total_pages
      也会是0。这时,你的分页导航应该不显示,或者只显示一个“暂无数据”的提示。
    • 更重要的是,如果
      $total_pages
      是0,但用户尝试访问
      ?page=1
      ,或者
      $current_page
      依然是默认值1,这时查询数据就会出现
      OFFSET
      计算错误或者返回空结果。所以,在计算完
      $total_pages
      后,我习惯加一个检查:
      if ($total_pages > 0 && $current_page > $total_pages) {
          $current_page = $total_pages; // 如果当前页码超出总页数,将其调整为最后一页
      } elseif ($total_pages == 0) {
          $current_page = 1; // 如果没有数据,页码设为1,但实际不会有数据查询出来
      }

      这样做的好处是,即使没有数据,

      $current_page
      也保持一个合理的默认值,避免了后续逻辑可能出现的意外,同时前端也能根据
      $total_pages
      是否大于1来决定是否显示分页导航。

PHP分页链接生成有哪些常见策略?如何提升用户体验和SEO友好性?

分页链接的生成是用户与分页功能交互的界面。一个好的分页导航不仅要功能完善,还要考虑用户体验和潜在的SEO影响。

常见策略:

  1. 基础“上一页/下一页”:这是最简单的形式,只提供前后翻页的链接。

    if ($current_page > 1) { echo "上一页"; }
    if ($current_page < $total_pages) { echo "下一页"; }
  2. 显示所有页码:适用于总页数不多的情况。

    for ($i = 1; $i <= $total_pages; $i++) {
        if ($i == $current_page) { echo "" . $i . ""; }
        else { echo "" . $i . ""; }
    }
  3. 显示部分页码(常用且推荐):当总页数很多时,显示所有页码会拉得很长,影响美观和体验。通常会显示当前页码附近的一小段页码,例如当前页码前后各2个页码,加上“首页”和“末页”链接。

    // 首页
    if ($current_page > 1) { echo "首页 "; }
    // 上一页
    if ($current_page > 1) { echo "上一页 "; }
    
    // 页码范围
    $start_page = max(1, $current_page - 2);
    $end_page = min($total_pages, $current_page + 2);
    
    for ($i = $start_page; $i <= $end_page; $i++) {
        if ($i == $current_page) { echo "" . $i . " "; }
        else { echo "" . $i . " "; }
    }
    
    // 下一页
    if ($current_page < $total_pages) { echo "下一页 "; }
    // 末页
    if ($current_page < $total_pages) { echo "末页"; }

    还可以加入

    ...
    来表示省略的页码,让导航更简洁。

提升用户体验:

  • 高亮当前页码:让用户清楚知道自己在哪一页。
  • 禁用不可用链接:例如,在第一页时禁用“上一页”和“首页”链接,或者让它们不可点击。
  • 快速跳转:可以考虑添加一个输入框,让用户直接输入页码跳转。
  • 响应式设计:在移动端,分页导航可能需要更简洁,例如只显示“上一页/下一页”或下拉选择页码。

SEO友好性:

对于分页内容,SEO的考量略显复杂,因为分页页面通常被视为相同内容的变体。

  1. 使用

    rel="prev"
    rel="next"
    :这是Google推荐的方式,用于告诉搜索引擎这些页面是系列内容的一部分。 在
    head
    标签中添加:

     1): ?>
        
    
    
        
    

    这有助于搜索引擎理解页面之间的关系,并可能将权重集中到第一页或主要内容页。

  2. rel="canonical"
    标签:如果分页页面上的内容是某个“主页面”的子集,或者你希望搜索引擎只索引第一页,可以将所有分页页面都指向第一页。

    但通常对于文章列表或产品列表这类分页,

    rel="prev/next"
    更合适,因为每个分页页面都有其独特的URL和部分内容。如果内容是重复的(例如,同一个产品列表,只是排序不同),那才考虑指向一个标准URL。

  3. 友好的URL结构(可选但推荐):虽然

    ?page=X
    这种形式很常见,但如果你的项目允许,使用更语义化的URL会更好,例如
    /articles/page/2
    /articles/2
    。这通常需要URL重写(如Apache的
    mod_rewrite
    或Nginx的
    rewrite
    模块)。
    example.com/articles?page=2
    example.com/articles/page/2
    (更友好)

  4. 避免重复内容:确保每个分页页面上的内容是不同的。如果只是排序不同,或者只有一两项内容差异,搜索引擎可能会将其视为重复内容。

总的来说,一个实用的分页功能,在保证基本逻辑正确和数据安全的前提下,通过精心设计的导航和适当的SEO标签,可以大大提升用户和搜索引擎的体验。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

1669

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1102

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1005

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

948

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1396

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1227

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1438

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1302

2023.11.13

苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

10

2025.12.24

热门下载

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

精品课程

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

共10课时 | 0.9万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.8万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

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

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