php分頁(yè)功能的實(shí)現(xiàn)方法:首先用“parse_url”解析得到的url數(shù)組;然后獲取list頁(yè),并將要展示的內(nèi)容集合;接著將計(jì)算的limit起始位置賦值給變量$page;最后使用$page和$pageSize去數(shù)據(jù)庫(kù)取數(shù)據(jù),并輸出展示。
成都創(chuàng)新互聯(lián)公司專業(yè)為企業(yè)提供隨州網(wǎng)站建設(shè)、隨州做網(wǎng)站、隨州網(wǎng)站設(shè)計(jì)、隨州網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)與制作、隨州企業(yè)網(wǎng)站模板建站服務(wù),十載隨州做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。
php分頁(yè)功能的實(shí)現(xiàn)
在網(wǎng)站中,如果list頁(yè)內(nèi)容太多,一般會(huì)設(shè)置分頁(yè)功能,今天我們一起來(lái)研究一下分頁(yè)原理,通過(guò)一個(gè)小案例實(shí)現(xiàn)這個(gè)功能.
推薦:《PHP教程》
分頁(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=1 2.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è)
網(wǎng)站名稱:關(guān)于php分頁(yè)功能的實(shí)現(xiàn)
本文地址:http://jinyejixie.com/article22/chodcc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站導(dǎo)航、網(wǎng)站排名、外貿(mào)網(wǎng)站建設(shè)、網(wǎng)站營(yíng)銷(xiāo)、建站公司、品牌網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)