关于php分页功能的实现

php分页功能的实现方法:首先用“parse_url”解析得到的url数组;然后获取list页,并将要展示的内容集合;接着将计算的limit起始位置赋值给变量$page;最后使用$page和$pageSize去数据库取数据,并输出展示。

成都创新互联公司专业为企业提供随州网站建设、随州做网站、随州网站设计、随州网站制作等企业网站建设、网页设计与制作、随州企业网站模板建站服务,十载随州做网站经验,不只是建网站,更提供有价值的思路和整体网络服务。

php分页功能的实现

在网站中,如果list页内容太多,一般会设置分页功能,今天我们一起来研究一下分页原理,通过一个小案例实现这个功能.

推荐:《PHP教程》

分页原理

分页显示,将从mysql数据库取出的数据有规律的一段段展示,利用sql语句中的limit,将它的起始数据跟页数绑定,根据页数去数据库取数据

例如:假设数据库表名为list,每页取10条信息

第1页    select * from list limit 0,10;
    第2页   select * from list limit 10,10;
    第3页   select * from list limit 20,10;

由此观之第n页 是select * from list limit (n-1)*10,10;

这样我们就得到了一个用页数取数据的公式:

select * from list limit ($page-1)*$pagesize,$pagesize; $page是当前的页数,$pagesize是每页取得条数

需要的知识点

1.基本的操作数据库函数
1.1 mysqli_connect();连接数据库,例如$link = mysqli_connect('127.0.0.1','root',12345678,'bbs'); 
1.2 mysqli_query():获取数据 例如$res = mysqli_query($link,"select * from list");第二个参数为sql语句
1.3 mysqli_num_rows():查看获取了多少条数据 例如 $num = mysqli_num_rows($res);
1.4 mysqli_fetch_assoc(),或者mysqli_fetch_row():从获取的数据集中取一条数据,每次只取一条,取完指针就指向下一条. 例如mysqli_fetch_assoc($res),除了fetch_assoc,fetch_row还有fetch_array,他们具体的区别请参考手册
1.5 limit 操作数据库中数据的,limit 开始位置,操作条数 例如从数据库中取数 select * from list limit 10,10;
2.其他相关知识
2.1 $_SERVER['REQUEST_URI']获取当前页面的url 例如 https://i.cnblogs.com/EditPosts.aspx?opt=1的url为/EditPosts.aspx?opt=1
2.2 parse_url():解析url,返回url的各个组成部分,如果不写第二个参数,返回的数组中可能的键有以下几种:
    scheme - 如 http,
    host
    port
    user
    pass
    path
    query - 在问号 ? 之后
    fragment - 在散列符号 # 之后

实现流程

1.获取当前url字符串,并用parse_url解析得到url数组

2.连接服务器,获取list页将要展示的内容集合,统计总共展示的条数,进而算出总共多少页内容

3.判断页面是否是提交状态,如果不是默认为第一页$pageval

4.将计算的limit起始位置赋值给变量$page

5.使用$page和$pageSize去数据库取数据

6.循环遍历得数据集合,输出展示在页面上

具体代码如下

$url = $_SERVER['REQUEST_URI'];
$url = parse_url($url);
$url = $url['path'];
$pageSize = 4;
//连接服务器
$link = mysqli_connect('127.0.0.1','root',12345678,'bbs');
$res = mysqli_query($link,'select * from fenye');
$num = mysqli_num_rows($res);
$pageNum = ceil($num/$pageSize);
//判断页面是否是提交状态
if ( isset($_GET['page']) && $_GET['page'] >1) {
    $pageVal = $_GET['page'];
}else {
    $pageVal = 1;
}
//计算起始位置
$page = ($pageVal-1)*$pageSize;
//去数据库取数据
$res = $mysqli_query($link,"select * from fenye limit $page,$pageSize");
//如果$res有值,则循环便利结果展示输出在页面
if ($res) {
    while( $row = mysqli_fetch_assoc($res) ) {
    echo $row['name']. '|'.$row['age'].'<br/>';
    }
}
//html添加页数部分
<a href="?page=1">1</a>;
<a href="?page=2">2</a>;
<a href="?page=3">3</a>;
<a href="?page=4">4</a>;
<a href="?page=5">5</a>;
总共<?php echo $pageNum; ?>页,当前在<?php echo $pageVal;?>页

网站名称:关于php分页功能的实现
本文地址:https://www.cdcxhl.com/article22/chodcc.html

成都网站建设公司_创新互联,为您提供网站导航网站排名外贸网站建设网站营销建站公司品牌网站制作

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

搜索引擎优化