PHP分頁顯示的方法分析(附PHP通用分頁類別)
這篇文章主要介紹了PHP分頁顯示的方法,結合實例形式分析了php資料庫查詢及內容結合HTML分頁顯示的簡單操作技巧,並附帶一個PHP通用分頁類供大家參考使用,需要的朋友可以參考下方
本文實例講述了PHP分頁顯示的方法。分享給大家供大家參考,具體如下:
<?php header("content-type:text/html;charset=utf-8"); $currentpage = 1; if(isset($_GET['page'])) $currentpage = $_GET['page']; //连接数据库 $link = mysql_connect("localhost","root","") or die('连接失败'); mysql_select_db('myschool'); mysql_query('set names utf8'); $sql ="SELECT count(*) as 'count' from student";//查询记录的sql语句 $result = mysql_query($sql); $arr = mysql_fetch_array($result); $count = $arr['count']; $pagesize = 3; $pages = ceil($count/$pagesize);//共多少页 $prepage = $currentpage -1; if($prepage<=0) $prepage=1; $nextpage = $currentpage+1; if($nextpage >= $pages){ $nextpage = $pages; } $start =($currentpage-1) * $pagesize;//起始位置 $sql = "SELECT * from student limit $start,$pagesize"; echo $sql; // $sql = "select * from student"; $result = mysql_query($sql); ?> <!-- html部分 --> <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <table border="1"> <tr> <td>学号</td> <td>姓名</td> <td>性别</td> <td>年龄</td> </tr> <?php while($arr=mysql_fetch_array($result)){ ?> <td><?php echo $arr['number']; ?></td> <td><?php echo $arr['name']; ?></td> <td><?php echo $arr['sex']; ?></td> <td><?php echo $arr['age']; ?></td> </tr> <?php } ?> </table> <a href="<?php echo $_SERVER['PHP_SELF'].'?page='.$prepage; ?>" rel="external nofollow" >上一页</a> <a href="<?php echo $_SERVER['PHP_SELF'].'?page='.$nextpage; ?>" rel="external nofollow" >下一页</a> </body> </html>
#註:當一個檔案中有php和html兩種時,php檔案必須有結束標記
附:php通用分頁類別與用法:
Page.class.php檔案:
<?php /** * 分页类 * * 调用方式: * $p=new Page(总条数,显示页数,当前页码,每页显示条数,[链接]); * print_r($p->getPages()); //生成一个页码数组(键为页码,值为链接) * echo $p->showPages(1); //生成一个页码样式(可添加自定义样式) * */ /* 总条数,需要显示的页数,当前页,每页显示的条数,连接 生成一个一维数组,键为页码 值为连接 返回一个生成好样式的页码(并且可以根据自己需要添加样式) 默认样式 共45条记录,每页显示10条,当前第1/4页 [首页] [上页] [1] [2] [3] .. [下页] [尾页] */ class Page{ protected $count; //总条数 protected $showPages; //需要显示的页数 protected $countPages; //总页数 protected $currPage; //当前页 protected $subPages; //每页显示条数 protected $href; //连接 protected $page_arr=array(); //保存生成的页码 键页码 值为连接 /** * __construct 构造函数(获取分页所需参数) * @param int $count 总条数 * @param int $showPages 显示页数 * @param int $currPage 当前页数 * @param int $subPages 每页显示数量 * @param string $href 连接(不设置则获取当前URL) */ public function __construct($count,$showPages,$currPage,$subPages,$href=''){ $this->count=$count; $this->showPages=$showPages; $this->currPage=$currPage; $this->subPages=$subPages; //如果链接没有设置则获取当前连接 if(empty($href)){ $this->href=htmlentities($_SERVER['PHP_SELF']); }else{ $this->href=$href; } $this->construct_Pages(); } /** * getPages 返回页码数组 * @return array 一维数组 键为页码 值为链接 */ public function getPages(){ return $this->page_arr; } /** * showPages 返回生成好的页码 * @param int $style 样式 * @return string 生成好的页码 */ public function showPages($style=1){ $func='pageStyle'.$style; return $this->$func(); } /** * pageStyle1 分页样式(可参照这个添加自定义样式 例如pageStyle2()) * 样式 共45条记录,每页显示10条,当前第1/4页 [首页] [上页] [1] [2] [3] .. [下页] [尾页] * @return string */ protected function pageStyle1(){ /* 构造普通模式的分页 共4523条记录,每页显示10条,当前第1/453页 [首页] [上页] [1] [2] [3] .. [下页] [尾页] */ $pageStr='共'.$this->count.'条记录,每页显示'.$this->subPages.'条'; $pageStr.='当前第'.$this->currPage.'/'.$this->countPages.'页 '; $_GET['page'] = 1; $pageStr.='<span>[<a href="'.$this->href.'?'.http_build_query($_GET).'" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >首页</a>] </span>'; //如果当前页不是第一页就显示上页 if($this->currPage>1){ $_GET['page'] = $this->currPage-1; $pageStr.='<span>[<a href="'.$this->href.'?'.http_build_query($_GET).'" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >上页</a>] </span>'; } foreach ($this->page_arr as $k => $v) { $_GET['page'] = $k; $pageStr.='<span>[<a href="'.$v.'" rel="external nofollow" >'.$k.'</a>] </span>'; } //如果当前页小于总页数就显示下一页 if($this->currPage<$this->countPages){ $_GET['page'] = $this->currPage+1; $pageStr.='<span>[<a href="'.$this->href.'?'.http_build_query($_GET).'" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >下页</a>] </span>'; } $_GET['page'] = $this->countPages; $pageStr.='<span>[<a href="'.$this->href.'?'.http_build_query($_GET).'" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" >尾页</a>] </span>'; return $pageStr; } /** * construct_Pages 生成页码数组 * 键为页码,值为链接 * $this->page_arr=Array( * [1] => index.php?page=1 * [2] => index.php?page=2 * [3] => index.php?page=3 * ......) */ protected function construct_Pages(){ //计算总页数 $this->countPages=ceil($this->count/$this->subPages); //根据当前页计算前后页数 $leftPage_num=floor($this->showPages/2); $rightPage_num=$this->showPages-$leftPage_num; //左边显示数为当前页减左边该显示的数 例如总显示7页 当前页是5 左边最小为5-3 右边为5+3 $left=$this->currPage-$leftPage_num; $left=max($left,1); //左边最小不能小于1 $right=$left+$this->showPages-1; //左边加显示页数减1就是右边显示数 $right=min($right,$this->countPages); //右边最大不能大于总页数 $left=max($right-$this->showPages+1,1); //确定右边再计算左边,必须二次计算 for ($i=$left; $i <= $right; $i++) { $_GET['page'] = $i; $this->page_arr[$i]=$this->href.'?'.http_build_query($_GET); } } } ?>
用法範例demo.php:
#<?php /** * demo */ header("content-type:text/html;charset=utf8"); include('Page.class.php'); //引入类 //$p=new Page(总条数,显示页数,当前页码,每页显示条数,[链接]); //连接不设置则为当前链接 $page=isset($_GET['page']) ? $_GET['page'] : 1; $p=new Page(100,4,$page,8); //生成一个页码数组(键为页码,值为链接) echo "<pre class="brush:php;toolbar:false">"; print_r($p->getPages()); //样式 共45条记录,每页显示10条,当前第1/4页 [首页] [上页] [1] [2] [3] .. [下页] [尾页] echo $p->showPages(1);
相關推薦:
#
以上是PHP分頁顯示的方法分析(附PHP通用分頁類別)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

PHP 8.4 帶來了多項新功能、安全性改進和效能改進,同時棄用和刪除了大量功能。 本指南介紹如何在 Ubuntu、Debian 或其衍生版本上安裝 PHP 8.4 或升級到 PHP 8.4

本教程演示瞭如何使用PHP有效地處理XML文檔。 XML(可擴展的標記語言)是一種用於人類可讀性和機器解析的多功能文本標記語言。它通常用於數據存儲

JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

靜態綁定(static::)在PHP中實現晚期靜態綁定(LSB),允許在靜態上下文中引用調用類而非定義類。 1)解析過程在運行時進行,2)在繼承關係中向上查找調用類,3)可能帶來性能開銷。

字符串是由字符組成的序列,包括字母、數字和符號。本教程將學習如何使用不同的方法在PHP中計算給定字符串中元音的數量。英語中的元音是a、e、i、o、u,它們可以是大寫或小寫。 什麼是元音? 元音是代表特定語音的字母字符。英語中共有五個元音,包括大寫和小寫: a, e, i, o, u 示例 1 輸入:字符串 = "Tutorialspoint" 輸出:6 解釋 字符串 "Tutorialspoint" 中的元音是 u、o、i、a、o、i。總共有 6 個元

PHP的魔法方法有哪些? PHP的魔法方法包括:1.\_\_construct,用於初始化對象;2.\_\_destruct,用於清理資源;3.\_\_call,處理不存在的方法調用;4.\_\_get,實現動態屬性訪問;5.\_\_set,實現動態屬性設置。這些方法在特定情況下自動調用,提升代碼的靈活性和效率。

PHP和Python各有優勢,選擇依據項目需求。 1.PHP適合web開發,尤其快速開發和維護網站。 2.Python適用於數據科學、機器學習和人工智能,語法簡潔,適合初學者。

PHP是一種廣泛應用於服務器端的腳本語言,特別適合web開發。 1.PHP可以嵌入HTML,處理HTTP請求和響應,支持多種數據庫。 2.PHP用於生成動態網頁內容,處理表單數據,訪問數據庫等,具有強大的社區支持和開源資源。 3.PHP是解釋型語言,執行過程包括詞法分析、語法分析、編譯和執行。 4.PHP可以與MySQL結合用於用戶註冊系統等高級應用。 5.調試PHP時,可使用error_reporting()和var_dump()等函數。 6.優化PHP代碼可通過緩存機制、優化數據庫查詢和使用內置函數。 7
