PHP 實現分頁功能
阿新 • • 發佈:2018-11-17
在網站中,如果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;?>頁