91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何實現php的分頁功能

發布時間:2020-07-22 11:16:13 來源:億速云 閱讀:186 作者:Leah 欄目:編程語言

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

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

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(),或者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的分頁功能就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

阿鲁科尔沁旗| 乐都县| 樟树市| 晋城| 乌拉特中旗| 利津县| 五大连池市| 乌海市| 十堰市| 班戈县| 英吉沙县| 江山市| 兴业县| 北流市| 宣威市| 沙湾县| 河西区| 靖州| 伊吾县| 张家港市| 昌邑市| 海口市| 鄢陵县| 黎川县| 宁武县| 伽师县| 孟州市| 辽阳市| 南部县| 五常市| 吴堡县| 登封市| 格尔木市| 沁阳市| 波密县| 洮南市| 墨玉县| 呼玛县| 新干县| 礼泉县| 商洛市|