溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

php實(shí)現(xiàn)分頁(yè)顯示的方法

發(fā)布時(shí)間:2020-06-01 16:38:16 來(lái)源:億速云 閱讀:263 作者:鴿子 欄目:編程語(yǔ)言

php中如何設(shè)置分頁(yè)顯示

分頁(yè)原理

分頁(yè)顯示,將從mysql數(shù)據(jù)庫(kù)取出的數(shù)據(jù)有規(guī)律的一段段展示,利用sql語(yǔ)句中的limit,將它的起始數(shù)據(jù)跟頁(yè)數(shù)綁定,根據(jù)頁(yè)數(shù)去數(shù)據(jù)庫(kù)取數(shù)據(jù)

例如:假設(shè)數(shù)據(jù)庫(kù)表名為list,每頁(yè)取10條信息

    第1頁(yè)   select * from list limit 0,10;
    第2頁(yè)   select * from list limit 10,10;
    第3頁(yè)   select * from list limit 20,10;

由此觀之第n頁(yè) 是select * from list limit (n-1)*10,10;

這樣我們就得到了一個(gè)用頁(yè)數(shù)取數(shù)據(jù)的公式:

select * from list limit ($page-1)*$pagesize,$pagesize; $page是當(dāng)前的頁(yè)數(shù),$pagesize是每頁(yè)取得條數(shù)

需要的知識(shí)點(diǎn)

1.基本的操作數(shù)據(jù)庫(kù)函數(shù)

1.1 mysqli_connect();連接數(shù)據(jù)庫(kù),例如$link = mysqli_connect('127.0.0.1','root',12345678,'bbs');

1.2 mysqli_query():獲取數(shù)據(jù) 例如$res = mysqli_query($link,"select * from list");第二個(gè)參數(shù)為sql語(yǔ)句

1.3 mysqli_num_rows():查看獲取了多少條數(shù)據(jù) 例如 $num = mysqli_num_rows($res);

1.4 mysqli_fetch_assoc(),或者mysqli_fetch_row():從獲取的數(shù)據(jù)集中取一條數(shù)據(jù),每次只取一條,取完指針就指向下一條. 例如mysqli_fetch_assoc($res),除了fetch_assoc,fetch_row還有fetch_array,他們具體的區(qū)別請(qǐng)參考手冊(cè)

1.5 limit 操作數(shù)據(jù)庫(kù)中數(shù)據(jù)的,limit 開(kāi)始位置,操作條數(shù) 例如從數(shù)據(jù)庫(kù)中取數(shù) select * from list limit 10,10;

2.其他相關(guān)知識(shí)

2.1 $_SERVER['REQUEST_URI']獲取當(dāng)前頁(yè)面的url 例如 https://i.cnblogs.com/EditPosts.aspx?opt=1的url為/EditPosts.aspx?opt=12.2 parse_url():解析url,返回url的各個(gè)組成部分,如果不寫(xiě)第二個(gè)參數(shù),返回的數(shù)組中可能的鍵有以下幾種:
   scheme - 如 http,
   host
   port
   user
   pass
   path
   query - 在問(wèn)號(hào) ? 之后
   fragment - 在散列符號(hào) # 之后

實(shí)現(xiàn)流程

1.獲取當(dāng)前url字符串,并用parse_url解析得到url數(shù)組

2.連接服務(wù)器,獲取list頁(yè)將要展示的內(nèi)容集合,統(tǒng)計(jì)總共展示的條數(shù),進(jìn)而算出總共多少頁(yè)內(nèi)容

3.判斷頁(yè)面是否是提交狀態(tài),如果不是默認(rèn)為第一頁(yè)$pageval

4.將計(jì)算的limit起始位置賦值給變量$page

5.使用$page和$pageSize去數(shù)據(jù)庫(kù)取數(shù)據(jù)

6.循環(huán)便利得數(shù)據(jù)集合,輸出展示在頁(yè)面上

具體代碼如下

$url = $_SERVER['REQUEST_URI'];
$url = parse_url($url);
$url = $url['path'];
$pageSize = 4;//連接服務(wù)器$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);//判斷頁(yè)面是否是提交狀態(tài)if ( isset($_GET['page']) && $_GET['page'] >1) {
    $pageVal = $_GET['page'];
}else {
    $pageVal = 1;
}//計(jì)算起始位置$page = ($pageVal-1)*$pageSize;//去數(shù)據(jù)庫(kù)取數(shù)據(jù)$res = $mysqli_query($link,"select * from fenye limit $page,$pageSize");//如果$res有值,則循環(huán)便利結(jié)果展示輸出在頁(yè)面if ($res) {    while( $row = mysqli_fetch_assoc($res) ) {    echo $row['name']. '|'.$row['age'].'<br/>';
    }
}//html添加頁(yè)數(shù)部分<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; ?>頁(yè),當(dāng)前在<?php echo $pageVal;?>頁(yè)

以上就是php中如何設(shè)置分頁(yè)顯示的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注億速云其它相關(guān)文章!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI