首頁 > 後端開發 > PHP問題 > PHP如何分頁

PHP如何分頁

王林
發布: 2023-02-24 16:16:01
原創
2790 人瀏覽過

PHP如何分頁

在網站中,如果list頁內容太多,一般會設定分頁功能,今天我們一起來研究一下分頁原理,透過一個小案例實現這個功能.

分頁原理

分頁顯示,將從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(),或mymyi_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[&#39;name&#39;]. &#39;|&#39;.$row[&#39;age&#39;].&#39;<br/>&#39;;
    }
}//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影片教學

以上是PHP如何分頁的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板