亚洲最大看欧美片,亚洲图揄拍自拍另类图片,欧美精品v国产精品v呦,日本在线精品视频免费

  • 站長資訊網(wǎng)
    最全最豐富的資訊網(wǎng)站

    PHP如何分頁

    PHP如何分頁

    在網(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

    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;?>頁

    推薦教程:PHP視頻教程

    贊(0)
    分享到: 更多 (0)
    網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)