PHP——分页显示数据库内容
生活随笔
收集整理的這篇文章主要介紹了
PHP——分页显示数据库内容
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
test.php
<?phpheader("Content-Type:text/html;charset=utf-8");//加載分頁類include "page.class.php";//定義總數(shù)$total =0;//1.造連接對象$db = new mysqli("localhost","root","123","mydb");//2.判斷是否連接成功if(mysqli_connect_error()){ echo "連接失敗";//退出整個程序exit;}else{//3.寫SQL語句$sql = "select count(*) from ChinaStates";//4.執(zhí)行SQL語句$result = $db->query($sql);$sj = $result->fetch_row();$total = $sj[0];//造分頁類的對象$page = new Page($total,20,"",true);//$page->set('prev',">>");//查數(shù)據(jù)庫并且顯示$sqlshow = "select * from ChinaStates ".$page->limit;$resultall = $db->query($sqlshow);echo "<table width='100%' border='1'><tr><td>地區(qū)代號</td><td>地區(qū)名稱</td><td>地區(qū)父級代號</td><td>地區(qū)權(quán)限</td></tr>";while($row = $resultall->fetch_row()){echo "<tr><td>{$row[0]}</td><td>{$row[1]}</td><td>{$row[2]}</td><td>{$row[3]}</td></tr>";}echo "<tr><td colspan='4'>".$page->fpage()."</td></tr>";echo "</table>";}定義的類
<?php/**file: page.class.php 完美分頁類 Page */class Page {private $total; //數(shù)據(jù)表中總記錄數(shù)private $listRows; //每頁顯示行數(shù)private $limit; //SQL語句使用limit從句,限制獲取記錄個數(shù)private $uri; //自動獲取url的請求地址private $pageNum; //總頁數(shù)private $page; //當(dāng)前頁 private $config = array('head' => "條記錄", 'prev' => "上一頁", 'next' => "下一頁", 'first'=> "首頁", 'last' => "末頁"); //在分頁信息中顯示內(nèi)容,可以自己通過set()方法設(shè)置private $listNum = 10; //默認(rèn)分頁列表顯示的個數(shù)/**構(gòu)造方法,可以設(shè)置分頁類的屬性@param int $total 計算分頁的總記錄數(shù)@param int $listRows 可選的,設(shè)置每頁需要顯示的記錄數(shù),默認(rèn)為25條@param mixed $query 可選的,為向目標(biāo)頁面?zhèn)鬟f參數(shù),可以是數(shù)組,也可以是查詢字符串格式@param bool $ord 可選的,默認(rèn)值為true, 頁面從第一頁開始顯示,false則為最后一頁*/public function __construct($total, $listRows=25, $query="", $ord=true){$this->total = $total; //總記錄數(shù)$this->listRows = $listRows;$this->uri = $this->getUri($query);$this->pageNum = ceil($this->total / $this->listRows);//總頁數(shù)/*以下判斷用來設(shè)置當(dāng)前面*/if(!empty($_GET["page"])) {$page = $_GET["page"];}else{if($ord)$page = 1;else$page = $this->pageNum;}if($total > 0) {if(preg_match('/\D/', $page) ){ //匹配數(shù)字(0-9)$this->page = 1;}else{$this->page = $page;}}else{$this->page = 0;}$this->limit = "LIMIT ".$this->setLimit();}/**用于設(shè)置顯示分頁的信息,可以進行連貫操作@param string $param 是成員屬性數(shù)組config的下標(biāo)@param string $value 用于設(shè)置config下標(biāo)對應(yīng)的元素值@return object 返回本對象自己$this, 用于連慣操作*/function set($param, $value){ //將上一頁改成"<<"if(array_key_exists($param, $this->config)){$this->config[$param] = $value;}return $this;}/* 不是直接去調(diào)用,通過該方法,可以使用在對象外部直接獲取私有成員屬性limit和page的值 */function __get($args){if($args == "limit" || $args == "page")return $this->$args;elsereturn null;}/**按指定的格式輸出分頁@param int 0-7的數(shù)字分別作為參數(shù),用于自定義輸出分頁結(jié)構(gòu)和調(diào)整結(jié)構(gòu)的順序,默認(rèn)輸出全部結(jié)構(gòu)@return string 分頁信息內(nèi)容*/function fpage(){$arr = func_get_args();$html[0] = " 共<b> {$this->total} </b>{$this->config["head"]} ";$html[1] = " 本頁 <b>".$this->disnum()."</b> 條 ";$html[2] = " 本頁從 <b>{$this->start()}-{$this->end()}</b> 條 ";$html[3] = " <b>{$this->page}/{$this->pageNum}</b>頁 ";$html[4] = $this->firstprev();$html[5] = $this->pageList();$html[6] = $this->nextlast();$html[7] = $this->goPage();$fpage = '<div style="font:12px \'\5B8B\4F53\',san-serif;">';if(count($arr) < 1)$arr = array(0, 1,2,3,4,5,6,7);for($i = 0; $i < count($arr); $i++)$fpage .= $html[$arr[$i]];$fpage .= '</div>';return $fpage;}/* 在對象內(nèi)部使用的私有方法,*/private function setLimit(){if($this->page > 0)return ($this->page-1)*$this->listRows.", {$this->listRows}";elsereturn 0;}/* 在對象內(nèi)部使用的私有方法,用于自動獲取訪問的當(dāng)前URL */private function getUri($query){ $request_uri = $_SERVER["REQUEST_URI"]; $url = strstr($request_uri,'?') ? $request_uri : $request_uri.'?';if(is_array($query))$url .= http_build_query($query);else if($query != "")$url .= "&".trim($query, "?&");$arr = parse_url($url);if(isset($arr["query"])){parse_str($arr["query"], $arrs);unset($arrs["page"]);$url = $arr["path"].'?'.http_build_query($arrs);}if(strstr($url, '?')) {if(substr($url, -1)!='?')$url = $url.'&';}else{$url = $url.'?';}return $url;}/* 在對象內(nèi)部使用的私有方法,用于獲取當(dāng)前頁開始的記錄數(shù) */private function start(){if($this->total == 0)return 0;elsereturn ($this->page-1) * $this->listRows+1;}/* 在對象內(nèi)部使用的私有方法,用于獲取當(dāng)前頁結(jié)束的記錄數(shù) */private function end(){return min($this->page * $this->listRows, $this->total);}/* 在對象內(nèi)部使用的私有方法,用于獲取上一頁和首頁的操作信息 */private function firstprev(){if($this->page > 1) {$str = " <a href='{$this->uri}page=1'>{$this->config["first"]}</a> ";$str .= "<a href='{$this->uri}page=".($this->page-1)."'>{$this->config["prev"]}</a> "; return $str;}}/* 在對象內(nèi)部使用的私有方法,用于獲取頁數(shù)列表信息 */private function pageList(){$linkPage = " <b>";$inum = floor($this->listNum/2);/*當(dāng)前頁前面的列表 */for($i = $inum; $i >= 1; $i--){$page = $this->page-$i;if($page >= 1)$linkPage .= "<a href='{$this->uri}page={$page}'>{$page}</a> ";}/*當(dāng)前頁的信息 */if($this->pageNum > 1)$linkPage .= "<span style='padding:1px 2px;background:#BBB;color:white'>{$this->page}</span> ";/*當(dāng)前頁后面的列表 */for($i=1; $i <= $inum; $i++){$page = $this->page+$i;if($page <= $this->pageNum)$linkPage .= "<a href='{$this->uri}page={$page}'>{$page}</a> ";elsebreak;}$linkPage .= '</b>';return $linkPage;}/* 在對象內(nèi)部使用的私有方法,獲取下一頁和尾頁的操作信息 */private function nextlast(){if($this->page != $this->pageNum) {$str = " <a href='{$this->uri}page=".($this->page+1)."'>{$this->config["next"]}</a> ";$str .= " <a href='{$this->uri}page=".($this->pageNum)."'>{$this->config["last"]}</a> ";return $str;}}/* 在對象內(nèi)部使用的私有方法,用于顯示和處理表單跳轉(zhuǎn)頁面 */private function goPage(){if($this->pageNum > 1) { //!important優(yōu)先調(diào)用return ' <input style="width:20px;height:17px !important;height:18px;border:1px solid #CCCCCC;" type="text" οnkeydοwn="javascript:if(event.keyCode==13){var page=(this.value>'.$this->pageNum.')?'.$this->pageNum.':this.value;location=\''.$this->uri.'page=\'+page+\'\'}" value="'.$this->page.'"><input style="cursor:pointer;width:25px;height:18px;border:1px solid #CCCCCC;" type="button" value="GO" οnclick="javascript:var page=(this.previousSibling.value>'.$this->pageNum.')?'.$this->pageNum.':this.previousSibling.value;location=\''.$this->uri.'page=\'+page+\'\'"> ';}}/* 在對象內(nèi)部使用的私有方法,用于獲取本頁顯示的記錄條數(shù) */private function disnum(){if($this->total > 0){return $this->end()-$this->start()+1;}else{return 0;}}}?> page.class.php?
使用方法:
主要函數(shù):__construct(數(shù)據(jù)的個數(shù),[顯示的條數(shù),默認(rèn)25,[$query="",[$sord= true | false true代表從第一頁開始,false在最后一頁開始]]]);
fpage();返回下面的html代碼(字符串的形式),可以輸入(1-7)來指定顯示的順序
步驟:實例化對象-->取limit語句-->調(diào)用fpage()-->設(shè)置跳頁下腳
轉(zhuǎn)載于:https://www.cnblogs.com/Chenshuai7/p/5197498.html
總結(jié)
以上是生活随笔為你收集整理的PHP——分页显示数据库内容的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: HttpUrlConnection ge
- 下一篇: mongodb3.2系统性学习——5、游