如何實(shí)現(xiàn)php的分頁功能

這篇文章運(yùn)用簡單易懂的例子給大家介紹如何實(shí)現(xiàn)php的分頁功能,代碼非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

成都創(chuàng)新互聯(lián)專注于勐海網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠為您提供勐海營銷型網(wǎng)站建設(shè),勐海網(wǎng)站制作、勐海網(wǎng)頁設(shè)計(jì)、勐海網(wǎng)站官網(wǎng)定制、成都微信小程序服務(wù),打造勐海網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供勐海網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。

php分頁功能的實(shí)現(xiàn)方法:首先用“parse_url”解析得到的url數(shù)組;然后獲取list頁,并將要展示的內(nèi)容集合;接著將計(jì)算的limit起始位置賦值給變量$page;最后使用$page和$pageSize去數(shù)據(jù)庫取數(shù)據(jù),并輸出展示。

php分頁功能的實(shí)現(xiàn)

在網(wǎng)站中,如果list頁內(nèi)容太多,一般會(huì)設(shè)置分頁功能,今天我們一起來研究一下分頁原理,通過一個(gè)小案例實(shí)現(xiàn)這個(gè)功能.

分頁原理

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

例如:假設(shè)數(shù)據(jù)庫表名為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;

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

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

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

1.基本的操作數(shù)據(jù)庫函數(shù)
1.1 mysqli_connect();連接數(shù)據(jù)庫,例如$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語句
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ū)別請參考手冊
1.5 limit 操作數(shù)據(jù)庫中數(shù)據(jù)的,limit 開始位置,操作條數(shù) 例如從數(shù)據(jù)庫中取數(shù) select * from list limit 10,10;
2.其他相關(guān)知識(shí)
2.1 $_SERVER['REQUEST_URI']獲取當(dāng)前頁面的url 例如 https://i.cnblogs.com/EditPosts.aspx?opt=1的url為/EditPosts.aspx?opt=1
2.2 parse_url():解析url,返回url的各個(gè)組成部分,如果不寫第二個(gè)參數(shù),返回的數(shù)組中可能的鍵有以下幾種:
    scheme - 如 http,
    host
    port
    user
    pass
    path
    query - 在問號(hào) ? 之后
    fragment - 在散列符號(hào) # 之后

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

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

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

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

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

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

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

具體代碼如下

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

關(guān)于如何實(shí)現(xiàn)php的分頁功能就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。

名稱欄目:如何實(shí)現(xiàn)php的分頁功能
分享網(wǎng)址:http://muchs.cn/article48/joggep.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供軟件開發(fā)、外貿(mào)建站、品牌網(wǎng)站建設(shè)網(wǎng)站內(nèi)鏈、網(wǎng)站收錄關(guān)鍵詞優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都做網(wǎng)站