`
呼延浩云
  • 浏览: 84828 次
  • 性别: Icon_minigender_1
  • 来自: 北京
博客专栏
69e5c1d2-1364-320a-a0f2-0de5143310d8
互联网的那点事
浏览量:10972
社区版块
存档分类
最新评论

怎么使用PHP和MySQL创建个性的网站分页

阅读更多

pagination

 

分页起着重要的作用,在任何Web应用程序,具有足够大的数据被分成页。它不仅外观整洁,但也提高了一个网页的加载时间。所以,分页是很重要的一个改进的用户界面,并节省服务器资源。在本教程中,我会告诉你一个简单的方法来创建在PHP中,同时获取数据从MySQL分页。所以,让我们开始吧。

 

 

寻找jQuery的分页?这是在这里

 

我刚才提到下面这个分页教程经常会用到的三个重要变量。

 
1
2
3
$page; // This variable contains the current page number
$limit; // The number of posts / articles to show on each page
$total_posts; // The total number of posts available in the database

现在,看看下面的代码,并揣摩自己什么它是所有关于。不要担心,如果你有无法作为代码始终是很好的注释。

 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
/*
* Trying to get the page number if the $_GET['p'] parameter is set. If not, set the $page variable to 1.
*/
if(isset($_GET['p'])) {
    $page = intval($_GET['p']);
        if(empty($page)) {
            $page = 1;
        }
}
 
/*
* $start variable as per the current page. We will be using this in our SQL queries.
*/
$start = ($page – 1) * $limit;
 
    /*
    * An important fix for the pagination.
    */
    if($start == $total_posts || $start > $total_posts) {
        $start = 0;
        $page = 1;
    }

首先,我们检查page参数是否是通过设置全局变量$ _GET这是一个GET请求,因为我们将在url中传递的页码。如果没有设置,那么$页= 1,这意味着我们是在第一页。然后,开始的变量的值被设置,因为它会被用在我们的SQL语句以及与限制变量提取结果。最后,我已经申请了一个小的分页修复,因此,如果有人试图在url这是我们的最后一页大于手动输入页码,分页复位的第一页。

这里是我编码,我们将使用在我们的网页链接显示的分页功能。

 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
function pagination($page, $total_pages, $limit) {
    /*
    * We are going to use $stages for creating the gap between pages in the pagination links.
    */
    $stages = 1;
 
    /*
    * The previous and next links.
    */
    $prev = $page – 1;
    $next = $page + 1;
 
    $lastpage = ceil($total_pages/$limit);
    $LastPagem1 = $lastpage – 1;
 
    $paginate = ”;
 
    if($lastpage > 1) {
        $paginate .= ‘<div>’;
 
        ## Previous
        if($page > 1) {
            $paginate .= ‘<a href=”?p=’.$prev.’”>previous</a>’;
        } else {
            $paginate .= ‘<span>previous</span>’;
        }
 
        ## Pages
        if($lastpage < 7 + ($stages * 2)) {
            for($counter = 1; $counter <= $lastpage; $counter++) {
                if($counter == $page) {
                    $paginate .= ‘<span>’.$counter.’</span>’;
                } else {
                    $paginate .= ‘<a href=”?p=’.$counter.’”>’.$counter.’</a>’;
                }
            }
        } elseif($lastpage > 5 + ($stages * 2)) {
            if($page < 1 + ($stages * 2)) {
                for($counter = 1; $counter < 4 + ($stages * 2); $counter++) {
                    if($counter == $page) {
                        $paginate .= ‘<span>’.$counter.’</span>’;
                    } else {
                        $paginate .= ‘<a href=”?p=’.$counter.’”>’.$counter.’</a>’;
                    }
                }
 
                $paginate .= ‘…’;
                $paginate .= ‘<a href=”?p=’.$LastPagem1.’”>’.$LastPagem1.’</a>’;
                $paginate .= ‘<a href=”?p=’.$lastpage.’”>’.$lastpage.’</a>’;
            } elseif($lastpage – ($stages * 2) > $page && $page > ($stages * 2)) {
                $paginate .= ‘<a href=”?p=1″>1</a>’;
                $paginate .= ‘<a href=”?p=2″>2</a>’;
                $paginate .= ‘…’;
                    for($counter = $page – $stages; $counter <= $page + $stages; $counter++) {
                        if($counter == $page) {
                            $paginate .= ‘<span>’.$counter.’</span>’;
                        } else {
                            $paginate .= ‘<a href=”?p=’.$counter.’”>’.$counter.’</a>’;
                        }
                    }
 
                $paginate .= ‘…’;
                $paginate .= ‘<a href=”?p=’.$LastPagem1.’”>’.$LastPagem1.’</a>’;
                $paginate .= ‘<a href=”?p=’.$lastpage.’”>’.$lastpage.’</a>’;
            } else {
                $paginate .= ‘<a href=”?p=1″>1</a>’;
                $paginate .= ‘<a href=”?p=2″>2</a>’;
                $paginate .= ‘…’;
                    for($counter = $lastpage – (2 + ($stages * 2)); $counter <= $lastpage; $counter++) {
                        if($counter == $page) {
                            $paginate .= ‘<span>’.$counter.’</span>’;
                        } else {
                            $paginate .= ‘<a href=”?p=’.$counter.’”>’.$counter.’</a>’;
                        }
                    }
            }
        }
 
        ## Next
        if($page < $counter – 1) {
            $paginate .= ‘<a href=”?p=’.$next.’”>next</a>’;
        } else {
            $paginate .= ‘<span>next</span>’;
        }
 
        $paginate .= ‘</div>’;
    }
 
    echo $paginate;
}

PHP函数上面有3个必需的参数- $页面,$ total_items,$限制下面写的SQL查询的格式会告诉你如何,我们将每当前页面显示结果。

 
$sql = “SELECT * FROM `posts` LIMIT {$start}, {$limit}”;

在这里,我们使用的是从我们的PHP代码开始$限制变量。比方说,你是在第3页,每一页上显示的项目是10,上面的查询将会像一个如下图所示。

1
$sql= “SELECT * FROM `posts` LIMIT 20, 10″;
 

现在,使用下面的代码到任何你想去的更换所需的参数为你的代码在您的网页上显示分页链接。

 
1
pagination($page, $total_posts, $limit);

这是所有需要在您的网站上实现分页系统。搁笔前,我已经在下面一节中的分页链接粘贴示例CSS。

 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
/*
  @@ Pagination
*/
.paginate {
  font-family: “arial”, sans-serif;
  padding: 3px;
  margin: 3px;
}
 
.paginate a {
  padding: 2px 5px;
  margin: 2px;
  border: 1px solid transparent;
  text-decoration: none;
  color: #333;
}
 
.paginate a:hover, .paginate a:active {
  border: 1px solid #ff0000;
  background: #ff0000;
  color: #fff;
}
 
.paginate span.current {
  margin: 2px;
  padding: 2px 5px;
  border: 1px solid #000;
  font-weight: bold;
  background-color: #000;
  color: #fff;
}
 
.paginate span.disabled {
  padding: 2px 5px;
  margin: 2px;
  color: #ddd;
}

本教程结束。我希望你喜欢阅读这篇文章。

本文来自李新的博客,转载请注明出处。http://www.ilixin.net/406.html

分享到:
评论

相关推荐

    MongoDB分片集群搭建教程:副本集创建与数据分片

    内容概要:本文提供了详细的MongoDB分片集群的搭建指导,涵盖了从环境准备、配置文件编写、副本集的建立、主节点的选择、配置服务器和数据分片服务器的配置到最后的路由节点的搭建与操作整个流程,以及对数据库的哈希与范围两种分片策略的应用介绍和具体命令执行。 适合人群:熟悉NoSQL数据库概念并对MongoDB有一定了解的技术人员,尤其是在大型数据管理和分布式数据库架构设计中有需求的开发者。 使用场景及目标:帮助技术人员掌握构建高效能、高可用性的MongoDB分片集群的方法,适用于处理大规模、实时性强的数据存储与读取场景。 其他说明:文中通过实例演示了每个步骤的具体操作方法,便于跟随文档实操,同时也介绍了可能遇到的问题及其解决方案,如在没有正确配置的情况下试图写入数据时出现错误等情况的处理。

    CPPC++_嵌入式硬件的物联网解决方案blinker库与Arduino ESP8266 ESP32一起工作.zip

    CPPC++_嵌入式硬件的物联网解决方案blinker库与Arduino ESP8266 ESP32一起工作

    CPPC++_逆向调用QQ Mojo IPC与WeChat XPlugin.zip

    CPPC++_逆向调用QQ Mojo IPC与WeChat XPlugin

    CPPC++_现代活动指标.zip

    CPPC++_现代活动指标

    CPPC++_Xournal是一款手写笔记软件,支持PDF注释,使用C语言编写,支持GTK3,支持Linux,如Ubu.zip

    CPPC++_Xournal是一款手写笔记软件,支持PDF注释,使用C语言编写,支持GTK3,支持Linux,如Ubu

    基于SSM学生实习管理系统前台小程序与后台管理系统开发实践

    资源概述: 本资源提供了一套完整的学生实习管理系统解决方案,涵盖了前台小程序页面与后台管理系统两大模块。前台小程序页面设计简洁直观,用户可根据不同身份(学生或企业)进行登录。学生用户能够方便地浏览并投递感兴趣的实习岗位,而企业用户则能轻松发布实习信息,吸引优秀人才。后台管理系统功能全面,包括个人中心、首页、学生管理、教师管理、企业管理、招聘管理、评分管理以及实习管理等多个方面,为管理员提供了强大的数据管理和操作工具。 技术栈亮点: SSM框架:系统后台采用Spring、Spring MVC和MyBatis Plus(简称SSM)作为核心开发框架,确保了系统的稳定性、可扩展性和可维护性。Spring作为控制反转(IoC)和面向切面编程(AOP)的容器,为系统提供了强大的业务逻辑处理能力;Spring MVC则负责处理Web请求和响应,实现了前后端的分离;MyBatis Plus作为持久层框架,简化了数据库操作,提高了开发效率。 MySQL数据库:系统采用MySQL作为数据库存储解决方案,支持大数据量的存储和高效查询。 如有侵权请联系我删除,谢谢

    微服务闪聚支付项目.zip

    微服务闪聚支付项目

    Rust 与 Java 互调实战示例

    博客链接 https://blog.csdn.net/weixin_47560078/article/details/143714557 文章从原理介绍出发,实现了 Rust 与 Java 的互调。利用 JNI 技术,可以充分发挥 Rust 的性能优势,同时保持 Java 的跨平台特性。这种技术组合适用于对性能要求较高的应用场景,如图像处理、数据分析和系统级编程等。

    CPPC++_这是我翻译的艾根中文文档.zip

    cppc++

    Matlab实现斑马优化算法ZOA-TCN-Multihead-Attention多输入单输出回归预测算法研究.rar

    1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。 替换数据可以直接使用,注释清楚,适合新手

    Matlab实现雪融优化算法SAO-TCN-Multihead-Attention多输入单输出回归预测算法研究.rar

    1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。 替换数据可以直接使用,注释清楚,适合新手

    分布式事务lcn.zip

    分布式事务lcn

    基于Simulink的正弦波PWM技术和三次谐波注入PWM技术研究.rar

    1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。

    【风电功率预测】基于BiTCN的风电功率多变量输入预测研究附Matlab代码.rar

    1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。

    CPPC++_这是由一块迷你带OV2640双DRV8833驱动TypeC接口PSRAM的ESP32PicoD4开发板驱.zip

    cppc++

    JAVA安卓手机与电脑的socket通信源码数据库 其他源码类型 WinForm

    安卓手机与电脑的socket通信源码

    Anaconda:JupyterNotebook使用教程.docx

    Anaconda:JupyterNotebook使用教程.docx

    Amazon S3:S3静态网站托管教程.docx

    Amazon S3:S3静态网站托管教程.docx

    Python商品销售数据分析可视化项目源码(期末大作业).zip

    Python商品销售数据分析可视化项目源码(期末大作业).zip,个人经导师指导并认可通过的98分大作业设计项目。主要针对计算机相关专业的正在做期末大作业设计的学生和需要项目实战练习的学习者,可作为课程设计、期末大作业,代码资料完整下载可用。 Python商品销售数据分析可视化项目源码(期末大作业).zip,个人经导师指导并认可通过的98分大作业设计项目。主要针对计算机相关专业的正在做期末大作业设计的学生和需要项目实战练习的学习者,可作为课程设计、期末大作业,代码资料完整下载可用。Python商品销售数据分析可视化项目源码(期末大作业).zip,个人经导师指导并认可通过的98分大作业设计项目。主要针对计算机相关专业的正在做期末大作业设计的学生和需要项目实战练习的学习者,可作为课程设计、期末大作业,代码资料完整下载可用。Python商品销售数据分析可视化项目源码(期末大作业).zip,个人经导师指导并认可通过的98分大作业设计项目。主要针对计算机相关专业的正在做期末大作业设计的学生和需要项目实战练习的学习者,可作为课程设计、期末大作业,代码资料完整下载可用。Python商品销售数据分析

    CPPC++_wechathookWeChatApi微信Api微信hook微信接口python微信接口java微信Ap.zip

    CPPC++_wechathookWeChatApi微信Api微信hook微信接口python微信接口java微信Ap

Global site tag (gtag.js) - Google Analytics