php分頁函數(shù) [經(jīng)典]
Jun 08, 2016 pm 05:32 PM";
/*
??分頁類
??design by xqbar
??qq:174171262
??email:wxddong@163.com
??blog:http://www.xqbar.com
??考慮輸入?yún)?shù)
??size(每頁記錄數(shù)目)
??url(連接地址)
??style(分頁樣式)
??sql(運行語句)
*/
class page{
? ?public??$sql='';//分頁sql語句
? ?public??$url='';//分頁傳遞過來的下頁地址,可以另外加參數(shù)用來搜索使用
? ?public??$size=10;//默認每頁顯示數(shù)據(jù)10條
? ?public??$style=1;//默認分頁顯示風格
? ?private $totalsize=0;//數(shù)據(jù)總數(shù)
? ?private $totalpage=0;//總頁數(shù)
? ?private $page=1;//當前頁
? ?private $link;//數(shù)據(jù)庫連接點
? ?private $flag=false;//初始化標志點
? ?private $offset=0;//分頁偏移值 limit $offset,$size;
? ?//構造函數(shù) 傳遞數(shù)據(jù)庫連接點
? ?function __construct($link){
? ?? ?$this->page=(isset($_GET['page'])&&!empty($_GET['page'])&&(int)($_GET['page']))?(int)$_GET['page']:1;//獲取當前page參數(shù)值,確定當前是第幾分頁
? ?? ?$this->link=$link;
? ?}
? ?//析構函數(shù)
? ?function __destruct(){
??@mysql_close($this->link);
??$this->link=NULL;
? ?}
??//構造函數(shù)兼顧
? ???$this->__construct($link);
? ?}
? ?//初始化
? ?function init(){
? ???if(empty($this->sql)){$this->halt("錯誤警告:sql語句不能為空!");exit();}//判斷sql是否存在
??$this->sql=str_replace(sql);//">'@_',DB_PREFIX,$this->sql);//替換sql中的表前綴
? ???$this->size=($this->sizesize;//初始每頁顯示數(shù)據(jù)條數(shù)
??$this->page=($this->pagepage;//當前頁碼值
? ???#大于第一頁后優(yōu)化查詢總記錄數(shù)
??//這里我使用了第一次瀏覽分頁時查詢數(shù)據(jù)庫得出數(shù)據(jù)庫總數(shù),點下頁時傳遞并不再查詢數(shù)據(jù)庫,數(shù)據(jù)量多時可能會節(jié)省些(自己想的)
??if($this->page==1&&!isset($_GET['tsize'])){
? ???sql">$result=@mysql_query($this->sql);
? ???$this->totalsize=@mysql_num_rows($result);
? ???@mysql_free_result($result);
??}else{
? ?? ? //上面的問題唯一缺點就是用戶手動在地址欄更改了tsize值后分頁將不再正確
? ???$this->totalsize=(int)$_GET['tsize'];
? ? }
? ???$this->url=(empty($this->url))?$_SERVER['PHP_SELF'].'?tsize='.$this->totalsize:$this->url.'&tsize='.$this->totalsize;//傳遞totalsize給下一頁
??$this->totalpage=ceil($this->totalsize/$this->size);//獲取總頁數(shù)
??$this->page=($this->page>$this->totalpage)?$this->totalpage:$this->page;
??$this->offset=($this->page-1)*$this->size;//獲取偏移值
? ?}
??//查詢數(shù)據(jù)庫返回結果給二維數(shù)組
? ?function fetch_array($result_type=MYSQL_BOTH){
? ???if(!$this->flag){$this->init();$this->flag=true;}
? ???if($this->totalsize
??$this->sql.=" limit $this->offset,$this->size";
??sql,$this->link">$result=@mysql_query($this->sql,$this->link);
??while($row=mysql_fetch_array($result,$result_type)){$rows[]=$row;}
??@mysql_free_result($result);
??return $rows;
? ?}
??//獲取總數(shù)據(jù)數(shù)
? ?function getsize(){
? ???if(!$this->flag){$this-init();$this->flag=true;}//判斷是否已經(jīng)在此之前初始化過,是則直接返回 (下同)
? ???return $this->totalsize;
? ?}
//獲取總頁數(shù)
? ?function getpage(){
? ???if(!$this->flag){$this-init();$this->flag=true;}
? ???return $this->totalpage;
? ?}
//根據(jù)傳入?yún)?shù)輸出分頁鏈接
? ?function outpage(){
? ???if(!$this->flag){$this-init();$this->flag=true;}
??switch($this->style){
? ? #1 第x頁 共x頁 首頁 上一頁 下一頁 尾頁 x條/頁 共x頁
? ? case 1:
? ?? ?? ???$pagehtml="第{$this->page}頁 共{$this->totalpage}頁";
? ???$pagehtml.=($this->page==1)?" 首頁 上一頁":" 首頁 上一頁";
? ?? ?? ???$pagehtml.=($this->page==$this->totalpage)?" 下一頁 尾頁":" 下一頁 尾頁";
? ???$pagehtml.=" 共{$this->totalsize}條";
? ?? ?? ???break;
? ? #1 首頁 上一頁 下一頁 尾頁 x條/頁 共x頁
? ? case 2:
? ?? ?? ???$pagehtml="";
? ???$pagehtml.=($this->page==1)?" 首頁 上一頁":" 首頁 上一頁";
? ?? ?? ???$pagehtml.=($this->page==$this->totalpage)?" 下一頁 尾頁":" 下一頁 尾頁";
? ???$pagehtml.=" 共{$this->totalsize}條";
? ?? ?? ???break;
? ? #2 1 2 3 4 5
? ? case 3:
? ?? ?? ???$offset=(ceil($this->page/10)-1)*10;
? ???$pagehtml="";
? ???if($offset!=0){$pagehtml.="| ";}
? ???for($i=1;$i
? ?? ? $n=$i+$offset;
? ?? ? if($n>$this->totalpage){break;}
? ?? ? if($n==$this->page){$pagehtml.=" $n ";}
? ?? ? else{$pagehtml.=" $n ";}
? ???}
? ???if($ntotalpage){$pagehtml.=" >> >>|";}
? ???unset($offset,$i,$n);
? ?? ?? ???break;? ?
? ? #1
? ? default:
? ?? ?? ???$pagehtml="第{$this->page}頁 共{$this->totalpage}頁";
? ???$pagehtml.=($this->page==1)?" 首頁 上一頁":" 首頁 上一頁";
? ?? ?? ???$pagehtml.=($this->page==$this->totalpage)?" 下一頁 尾頁":"??下一頁 尾頁";
? ?? ?? ???break;? ?
??}
? ? return $pagehtml;
? ?}
//錯誤輸出
? ?function halt($msg){
??echo "";
??echo "";
??echo "\r\n";
??echo "
??echo "";
??echo "
??echo $msg;
??echo "
??echo "";
}
}
?>
?
require_once('mysql.class.php');
require_once('page.class.php');
$db=new mysql();
$link=$db->open();
#定義sql和url
$sql='select * from @_info';(@_是我的表定義前綴在傳入類后被替換掉)
$url='';
$mypage=new page($link);
$mypage->size=10;
$mypage->style=3;
$mypage->url=$url;
$mypage->sql=$sql." order by id desc";
$ls=$mypage->fetch_array(MYSQL_ASSOC);//得到返回的結果
if(count($ls)==0){
? ?echo '無結果';
}else{
foreach($ls as $value){
? ? echo $value['title'];
}
//分頁碼
echo $mypage->outpage();
}
?>

熱AI工具

Undress AI Tool
免費脫衣服圖片

Undresser.AI Undress
人工智能驅(qū)動的應用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover
用于從照片中去除衣服的在線人工智能工具。

Clothoff.io
AI脫衣機

Video Face Swap
使用我們完全免費的人工智能換臉工具輕松在任何視頻中換臉!

熱門文章

熱工具

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

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

禪工作室 13.0.1
功能強大的PHP集成開發(fā)環(huán)境

Dreamweaver CS6
視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版
神級代碼編輯軟件(SublimeText3)

Windows11將清新優(yōu)雅的設計帶到了最前沿;現(xiàn)代界面允許您個性化和更改最精細的細節(jié),例如窗口邊框。在本指南中,我們將討論分步說明,以幫助您在Windows操作系統(tǒng)中創(chuàng)建反映您的風格的環(huán)境。如何更改窗口邊框設置?按+打開“設置”應用。WindowsI轉(zhuǎn)到個性化,然后單擊顏色設置。顏色更改窗口邊框設置窗口11“寬度=”643“高度=”500“>找到在標題欄和窗口邊框上顯示強調(diào)色選項,然后切換它旁邊的開關。若要在“開始”菜單和任務欄上顯示主題色,請打開“在開始”菜單和任務欄上顯示主題

“你的組織要求你更改PIN消息”將顯示在登錄屏幕上。當在使用基于組織的帳戶設置的電腦上達到PIN過期限制時,就會發(fā)生這種情況,在該電腦上,他們可以控制個人設備。但是,如果您使用個人帳戶設置了Windows,則理想情況下不應顯示錯誤消息。雖然情況并非總是如此。大多數(shù)遇到錯誤的用戶使用個人帳戶報告。為什么我的組織要求我在Windows11上更改我的PIN?可能是您的帳戶與組織相關聯(lián),您的主要方法應該是驗證這一點。聯(lián)系域管理員會有所幫助!此外,配置錯誤的本地策略設置或不正確的注冊表項也可能導致錯誤。即

默認情況下,Windows11上的標題欄顏色取決于您選擇的深色/淺色主題。但是,您可以將其更改為所需的任何顏色。在本指南中,我們將討論三種方法的分步說明,以更改它并個性化您的桌面體驗,使其具有視覺吸引力。是否可以更改活動和非活動窗口的標題欄顏色?是的,您可以使用“設置”應用更改活動窗口的標題欄顏色,也可以使用注冊表編輯器更改非活動窗口的標題欄顏色。若要了解這些步驟,請轉(zhuǎn)到下一部分。如何在Windows11中更改標題欄的顏色?1.使用“設置”應用按+打開設置窗口。WindowsI前往“個性化”,然

任務欄縮略圖可能很有趣,但它們也可能分散注意力或煩人??紤]到您將鼠標懸停在該區(qū)域的頻率,您可能無意中關閉了重要窗口幾次。另一個缺點是它使用更多的系統(tǒng)資源,因此,如果您一直在尋找一種提高資源效率的方法,我們將向您展示如何禁用它。不過,如果您的硬件規(guī)格可以處理它并且您喜歡預覽版,則可以啟用它。如何在Windows11中啟用任務欄縮略圖預覽?1.使用“設置”應用點擊鍵并單擊設置。Windows單擊系統(tǒng),然后選擇關于。點擊高級系統(tǒng)設置。導航到“高級”選項卡,然后選擇“性能”下的“設置”。在“視覺效果”選

您是否在Windows安裝程序頁面上看到“出現(xiàn)問題”以及“OOBELANGUAGE”語句?Windows的安裝有時會因此類錯誤而停止。OOBE表示開箱即用的體驗。正如錯誤提示所表示的那樣,這是與OOBE語言選擇相關的問題。沒有什么可擔心的,你可以通過OOBE屏幕本身的漂亮注冊表編輯來解決這個問題。快速修復–1.單擊OOBE應用底部的“重試”按鈕。這將繼續(xù)進行該過程,而不會再打嗝。2.使用電源按鈕強制關閉系統(tǒng)。系統(tǒng)重新啟動后,OOBE應繼續(xù)。3.斷開系統(tǒng)與互聯(lián)網(wǎng)的連接。在脫機模式下完成OOBE的所

在Windows11上的顯示縮放方面,我們都有不同的偏好。有些人喜歡大圖標,有些人喜歡小圖標。但是,我們都同意擁有正確的縮放比例很重要。字體縮放不良或圖像過度縮放可能是工作時真正的生產(chǎn)力殺手,因此您需要知道如何對其進行自定義以充分利用系統(tǒng)功能。自定義縮放的優(yōu)點:對于難以閱讀屏幕上的文本的人來說,這是一個有用的功能。它可以幫助您一次在屏幕上查看更多內(nèi)容。您可以創(chuàng)建僅適用于某些監(jiān)視器和應用程序的自定義擴展配置文件??梢詭椭岣叩投擞布男阅堋K鼓梢愿玫乜刂破聊簧系膬?nèi)容。如何在Windows11

屏幕亮度是使用現(xiàn)代計算設備不可或缺的一部分,尤其是當您長時間注視屏幕時。它可以幫助您減輕眼睛疲勞,提高易讀性,并輕松有效地查看內(nèi)容。但是,根據(jù)您的設置,有時很難管理亮度,尤其是在具有新UI更改的Windows11上。如果您在調(diào)整亮度時遇到問題,以下是在Windows11上管理亮度的所有方法。如何在Windows11上更改亮度[10種方式解釋]單顯示器用戶可以使用以下方法在Windows11上調(diào)整亮度。這包括使用單個顯示器的臺式機系統(tǒng)以及筆記本電腦。讓我們開始吧。方法1:使用操作中心操作中心是訪問

Windows上的激活過程有時會突然轉(zhuǎn)向顯示包含此錯誤代碼0xc004f069的錯誤消息。雖然激活過程已經(jīng)聯(lián)機,但一些運行WindowsServer的舊系統(tǒng)可能會遇到此問題。通過這些初步檢查,如果這些檢查不能幫助您激活系統(tǒng),請?zhí)D(zhuǎn)到主要解決方案以解決問題。解決方法–關閉錯誤消息和激活窗口。然后,重新啟動計算機。再次從頭開始重試Windows激活過程。修復1–從終端激活從cmd終端激活WindowsServerEdition系統(tǒng)。階段–1檢查Windows服務器版本您必須檢查您使用的是哪種類型的W
