亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > PHP > 正文

一個功能比較高的分頁類(for PHP5.x)

2024-09-04 11:43:58
字體:
來源:轉載
供稿:網友

怕水平的不高,所以從來沒有放過任何代碼,這個類我已經用了很久,近來用面向對象方法重寫,適用于PHP5.x,特地扔出,不怕見笑,希望拋磚引玉。

這個類適用于配合數據庫查詢分頁,和數組分頁,下面有使用方法。 

  1.  
  2. /* 
  3.  
  4. * 名稱: 分頁類 
  5.  
  6. * 介紹: 適用于數組分頁和配合sql查詢的分頁 
  7.  
  8. * 作者: idlion || Moonfly  
  9.  
  10. * 創建時間: 20060218 
  11.  
  12. * 最后修改: 20070524 
  13.  
  14. */ 
  15.  
  16. class PageBreak { 
  17.  
  18. private $mTotalRowsNum = 0; // 總信息行數 
  19.  
  20. private $mCurPageNumber = 1; // 當前所在頁 
  21.  
  22. private $mTotalPagesNum = 1; // 總頁數 
  23.  
  24. private $mQueryString// 頁面傳遞的數據(url?后的字符串) 
  25.  
  26. private $mPageRowsNum = 20; // 每頁顯示行數 
  27.  
  28. private $mIndexBarLength = 5; // 索引條的頁數 
  29.  
  30. private $mIndexBar = ''// 頁碼索引條 
  31.  
  32. private $mPageInfo = ''// 分頁信息 
  33.  
  34. // 頁碼索引條樣式 
  35.  
  36. private $mNextButton = "8"
  37.  
  38. private $mPreButton = "7"
  39.  
  40. private $mFirstButton = "9"
  41.  
  42. private $mLastButton = ":"
  43.  
  44. private $mCssIndexBarCurPage = "fontweight:bold;color:#FF0000"
  45.  
  46. private $mCssIndexBarPage = ''
  47.  
  48. // 分頁信息樣式 
  49.  
  50. private $mCssPageInfoNumFont = 'color:#FF0000'
  51.  
  52. private $mCssPageInfoFont = ''
  53.  
  54. // 構造方法 
  55.  
  56. public function __construct(&$rSqlQuery$userPageRowsNum='') { 
  57.  
  58. if( !is_array($rSqlQuery) ) { 
  59.  
  60. $this>SetDbPageBreak($rSqlQuery$userPageRowsNum); 
  61.  
  62.  
  63. else { 
  64.  
  65. $this>SetArrayPageBreak($rSqlQuery$userPageRowsNum); 
  66.  
  67.  
  68.  
  69. // 設置數據庫型分頁 
  70.  
  71. private function SetDbPageBreak(&$rSqlQuery$userPageRowsNum='') { 
  72.  
  73. $this>SetDbTotalRowsNum($rSqlQuery); 
  74.  
  75. $this>SetTotalPagesNum($userPageRowsNum); 
  76.  
  77. if$this>mTotalPagesNum > 1 ) { 
  78.  
  79. $this>SetCurPageNumber(); 
  80.  
  81. $this>SetSqlQuery($rSqlQuery); 
  82.  
  83. $this>SetQueryString(); 
  84.  
  85. $this>SetIndexBar(); 
  86.  
  87. $this>SetPageInfo(); 
  88.  
  89.  
  90.  
  91. // 設置數組型分頁 
  92.  
  93. private function SetArrayPageBreak(&$rArray$userPageRowsNum=''$userTotalRowsNum='') { 
  94.  
  95. $this>SetArrayTotalRowsNum($rArray$userTotalRowsNum); 
  96.  
  97. $this>SetTotalPagesNum($userPageRowsNum); 
  98.  
  99. if$this>mTotalPagesNum > 1 ) { 
  100.  
  101. $this>SetCurPageNumber(); 
  102.  
  103. $this>SetArray($rArray); 
  104.  
  105. $this>SetQueryString(); 
  106.  
  107. $this>SetIndexBar(); 
  108.  
  109. $this>SetPageInfo(); 
  110.  
  111.  
  112.  
  113. // 數據庫型計算總行數 
  114.  
  115. private function SetDbTotalRowsNum($rSqlQuery) { 
  116.  
  117. $this>mTotalRowsNum = mysql_num_rows( mysql_query($rSqlQuery) ); 
  118.  
  119.  
  120. // 數組型計算總行數 
  121.  
  122. private function SetArrayTotalRowsNum($array) { 
  123.  
  124. $this>mTotalRowsNum = count($array); 
  125.  
  126.  
  127. // 計算總頁數 
  128.  
  129. private function SetTotalPagesNum($userPageRowsNum='') { 
  130.  
  131. if$userPageRowsNum ) { 
  132.  
  133. $this>mPageRowsNum = $userPageRowsNum
  134.  
  135.  
  136. $this>mTotalPagesNum = (int)( floor( ($this>mTotalRowsNum1)/$this>mPageRowsNum )+1 ); 
  137.  
  138.  
  139. // 計算當前頁數 
  140.  
  141. private function SetCurPageNumber() { 
  142.  
  143. if$_GET['cur_page'] ) { 
  144.  
  145. $this>mCurPageNumber = $_GET['cur_page']; 
  146.  
  147.  
  148.  
  149. // 修正Sql截取語句 
  150.  
  151. private function SetSqlQuery(&$rSqlQuery) { 
  152.  
  153. $start_number = ($this>mCurPageNumber1)*$this>mPageRowsNum; 
  154.  
  155. $rSqlQuery .= " LIMIT ".$start_number.",".$this>mPageRowsNum; 
  156.  
  157.  
  158. // 修正截取后的Array 
  159.  
  160. private function SetArray(&$rArray) { 
  161.  
  162. $start_number = ($this>mCurPageNumber1)*$this>mPageRowsNum; 
  163.  
  164. $rArray = array_slice($rArray$start_number$this>mPageRowsNum); 
  165.  
  166.  
  167. // 修正 $_GET 傳遞數據 
  168.  
  169. private function SetQueryString() { 
  170.  
  171. $query_string = $_SERVER['QUERY_STRING']; 
  172.  
  173. if ( $query_string == '' ) { 
  174.  
  175. $this>mQueryString = "?cur_page="
  176.  
  177.  
  178. else { 
  179.  
  180. $this>mQueryString = preg_replace("/&?cur_page=d+/"''$query_string); 
  181.  
  182. $this>mQueryString = "?".$this>mQueryString."&cur_page="
  183.  
  184.  
  185.  
  186. // 設置頁碼索引條 
  187.  
  188. private function GetPageIndex() { 
  189.  
  190. if$this>mTotalPagesNum <= $this>mIndexBarLength ) { 
  191.  
  192. $first_number = 1; 
  193.  
  194. $last_number = $this>mTotalPagesNum; 
  195.  
  196.  
  197. else { 
  198.  
  199. $offset = (int)floor($this>mIndexBarLength/2); 
  200.  
  201. if( ($this>mCurPageNumber$offset) <= 1 ) { 
  202.  
  203. $first_number = 1; 
  204.  
  205.  
  206. elseif( ($this>mCurPageNumber+$offset) > $this>mTotalPagesNum ) { 
  207.  
  208. $first_number = $this>mTotalPagesNum$this>mIndexBarLength+1; 
  209.  
  210.  
  211. else { 
  212.  
  213. $first_number = $this>mCurPageNumber$offset
  214.  
  215.  
  216. $last_number = $first_number+$this>mIndexBarLength1; 
  217.  
  218.  
  219. $last_number
  220.  
  221. for$i=$first_number$i<=$last_number$i++ ) { 
  222.  
  223. if$this>mCurPageNumber == $i ) { 
  224.  
  225. $page_index .= "".$i." "
  226.  
  227.  
  228. else { 
  229.  
  230. $page_index .= "".$i." "
  231.  
  232.  
  233.  
  234. return $page_index
  235.  
  236.  
  237. // 設置頁碼索引條 
  238.  
  239. private function SetIndexBar() { 
  240.  
  241. $this>mIndexBar = $this>GetNavFirstButton(); 
  242.  
  243. $this>mIndexBar .= $this>GetNavPreButton(); 
  244.  
  245. $this>mIndexBar .= $this>GetPageIndex(); 
  246.  
  247. $this>mIndexBar .= $this>GetNavNextButton(); 
  248.  
  249. $this>mIndexBar .= $this>GetNavLastButton(); 
  250.  
  251.  
  252. // 得到頁碼索引條 首頁按鈕 
  253.  
  254. private function GetNavFirstButton() { 
  255.  
  256. return "".$this>mFirstButton." "
  257.  
  258.  
  259. // 得到頁碼索引條 上一頁按鈕 
  260.  
  261. private function GetNavPreButton() { 
  262.  
  263. if$this>mCurPageNumber>1 ) { 
  264.  
  265. $pre_number = $this>mCurPageNumber1; 
  266.  
  267.  
  268. else { 
  269.  
  270. $pre_number = 1; 
  271.  
  272.  
  273. return "".$this>mPreButton." "
  274.  
  275.  
  276. // 得到頁碼索引條 下一頁按鈕 
  277.  
  278. private function GetNavNextButton() { 
  279.  
  280. if$this>mCurPageNumbermTotalPagesNum ) { 
  281.  
  282. $next_number = $this>mCurPageNumber+1; 
  283.  
  284.  
  285. else { 
  286.  
  287. $next_number = $this>mTotalPagesNum; 
  288.  
  289.  
  290. return "".$this>mNextButton." "
  291.  
  292.  
  293. // 得到頁碼索引條 末頁按鈕 
  294.  
  295. private function GetNavLastButton() { 
  296.  
  297. return "".$this>mLastButton." "
  298.  
  299.  
  300. // 設置分頁信息 
  301.  
  302. private function SetPageInfo() { 
  303.  
  304. $this>mPageInfo =""
  305.  
  306. $this>mPageInfo .= "共 ".$this>mTotalRowsNum." 條信息 | "
  307.  
  308. $this>mPageInfo .= "".$this>mPageRowsNum." 條/頁 | "
  309.  
  310. $this>mPageInfo .= "共 ".$this>mTotalPagesNum." 頁 | "
  311.  
  312. $this>mPageInfo .= "第 ".$this>mCurPageNumber." 頁"
  313.  
  314. $this>mPageInfo .= ""
  315.  
  316.  
  317. // 取出頁碼索引條 
  318.  
  319. public function GetIndexBar() { 
  320.  
  321. return $this>mIndexBar; 
  322.  
  323.  
  324. // 取出分頁信息 
  325.  
  326. public function GetPageInfo() { 
  327.  
  328. return $this>mPageInfo; 
  329.  
  330. ?> 

代碼用法1: 配合數據庫使用(例子中配合的是我自己的數據庫操作類和模版類)

  1. // 這是一個sql查詢語句,我們來對它的查詢結果作出分頁 
  2.  
  3. $sql = "select * from member"
  4.  
  5. // 讀取分頁類 
  6.  
  7. require_once("pagebreak.php"); 
  8.  
  9. // 分頁初始化 
  10.  
  11. // $sql就是上面的查詢語句 
  12.  
  13. // 20是每頁顯示的數量 
  14.  
  15. // 通過分頁類的初始化,這個查詢語句就被加上" limit ...... " 
  16.  
  17. $pagebreak = new PageBreak($sql, 20); 
  18.  
  19. // 生成分頁索引導航條 
  20.  
  21. $navbar = $pagebreak>GetPageInfo().$pagebreak>GetIndexBar(); 
  22.  
  23. // 查詢的結果(這里用我自己的類,不多說了) 
  24.  
  25. $result = $db>GetFieldsArray($sql
  26.  
  27. // 輸出查詢結果 
  28.  
  29. var_dump($result); 
  30.  
  31. // 輸出分頁索引導航條 
  32.  
  33. echo $navbar

代碼用法2: 配合要輸出的數組

  1. // 這是一個sql查詢語句,并得到查詢結果 
  2.  
  3. $sql = "select * from member"
  4.  
  5. $result = $db>GetFieldsArray($sql); 
  6.  
  7. // 讀取分頁類 
  8.  
  9. require_once("pagebreak.php"); 
  10.  
  11. // 分頁初始化 
  12.  
  13. // $result就是上面的查詢后得到的結果 
  14.  
  15. // 20是每頁顯示的數量 
  16.  
  17. // 通過分頁類的初始化,這個結果數組被自動截取成相應頁的信息內容 
  18.  
  19. $pagebreak = new PageBreak($result, 20); 
  20.  
  21. // 生成分頁索引導航條 
  22.  
  23. $navbar = $pagebreak>GetPageInfo().$pagebreak>GetIndexBar(); 
  24.  
  25. // 輸出查詢結果 
  26.  
  27. var_dump($result); 
  28.  
  29. // 輸出分頁索引導航條 
  30.  
  31. echo $navbar

下面是輸出樣式:

前半部分信息條,是$pagebreak>GetPageInfo()

后半部分分頁索引導航,是$pagebreak>GetIndexBar()

輸出內容和樣式可以很方便的在類中調整,很簡單,有興趣可以研究一下

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美性xxxx极品hd满灌| 中文字幕日韩在线观看| 欧美性高潮床叫视频| 深夜福利日韩在线看| 国产欧美日韩专区发布| 国内精品美女av在线播放| 成人激情免费在线| 亚洲色图美腿丝袜| 国产成人精品999| 欧美日韩国产在线看| 91免费的视频在线播放| 91亚洲精品久久久久久久久久久久| 欧美国产日产韩国视频| 日韩风俗一区 二区| 久久免费精品日本久久中文字幕| 国产一区二区三区18| 欧美黑人性猛交| 久久久久久国产精品美女| 91美女片黄在线观| 青青a在线精品免费观看| 97超级碰碰碰久久久| 色av吧综合网| 久久精品国产一区| 国产精品99久久久久久www| 欧美国产在线视频| 国产精品对白刺激| 亚洲丝袜一区在线| 日韩av在线免费观看| 亚洲欧美国产另类| 国产精品综合网站| 久久久久久国产精品美女| 亚洲欧美中文字幕| 亚洲自拍小视频免费观看| 精品女同一区二区三区在线播放| 亚洲一区二区三区xxx视频| 成人h片在线播放免费网站| 久久精品国产69国产精品亚洲| 日韩成人免费视频| 亚洲国产另类 国产精品国产免费| 日韩美女在线播放| 国产精品日韩欧美综合| 日韩精品欧美激情| 国产亚洲在线播放| 久久av.com| 日韩中文有码在线视频| 国产精品678| 亚洲a在线播放| 久久久久久久久国产精品| 91精品国产乱码久久久久久蜜臀| 久久99热精品这里久久精品| 国产亚洲欧洲高清一区| 91在线视频免费| 成人黄色av免费在线观看| 欧美精品18videosex性欧美| 亚洲欧美激情精品一区二区| 中文字幕视频在线免费欧美日韩综合在线看| 国产精品久久久久77777| 97国产精品视频人人做人人爱| 中文字幕免费国产精品| 欧美三级免费观看| 日韩精品高清视频| 欧美另类老肥妇| 91麻豆国产语对白在线观看| 亚洲欧美综合v| 国产一区二区三区在线免费观看| 精品福利视频导航| xvideos亚洲| 欧美精品激情在线观看| 精品偷拍一区二区三区在线看| 亚洲综合第一页| 成人黄色在线观看| 国产日韩精品在线观看| 全亚洲最色的网站在线观看| 日韩av影视综合网| 日韩国产欧美精品一区二区三区| 亚洲欧美日韩天堂| 亚洲欧美制服第一页| 不卡中文字幕av| 欧美国产激情18| 成人精品一区二区三区电影免费| 91av成人在线| 久久伊人精品一区二区三区| 欧美高清自拍一区| 久久手机精品视频| 5252色成人免费视频| 久久91亚洲精品中文字幕奶水| 日韩亚洲欧美中文高清在线| 国自在线精品视频| 亚洲精品一区中文字幕乱码| 国产+成+人+亚洲欧洲| 欧美性极品xxxx娇小| 久久久久免费精品国产| 久久综合国产精品台湾中文娱乐网| 国产精品永久免费视频| www欧美xxxx| 日韩欧美999| 欧美激情久久久久久| 美日韩精品视频免费看| 久久久精品欧美| 成人做爽爽免费视频| 亚洲韩国青草视频| 欧美自拍视频在线| 国产精品午夜视频| 亚洲欧洲日韩国产| 色偷偷88888欧美精品久久久| 色综合久久久久久中文网| 欧美成人精品在线播放| 自拍偷拍亚洲欧美| 亚洲色图国产精品| 日韩免费av一区二区| 国产精品成人va在线观看| 欧美疯狂xxxx大交乱88av| 日韩黄色av网站| 欧美国产视频日韩| 国产国语videosex另类| 欧美亚洲在线观看| 日本国产欧美一区二区三区| 国产精品久久久久久久久久久久| 国产精品嫩草影院久久久| 欧美专区在线观看| 日韩免费av一区二区| 日本中文字幕不卡免费| 夜夜狂射影院欧美极品| 国产91在线播放| 国产精品日韩一区| 欧美国产高跟鞋裸体秀xxxhd| 日韩欧美视频一区二区三区| 国内精品在线一区| 日韩精品在线影院| 日韩欧美aaa| 亚洲视频在线免费看| 成人淫片在线看| 91国内免费在线视频| 国产福利视频一区| 国产免费一区二区三区在线观看| 92裸体在线视频网站| 亚洲精品欧美日韩| 国产精品va在线播放| 国产一区二区日韩| 亚洲成色777777在线观看影院| 亚洲欧洲视频在线| 亚洲人免费视频| 欧美黑人狂野猛交老妇| 日韩美女免费视频| 一区二区三区精品99久久| 欧美理论电影在线播放| 在线观看视频99| 日韩中文字幕免费视频| 日韩精品在线看| 黄色精品一区二区| 亚洲色图狂野欧美| 亚洲精品福利在线| 欧美日韩中文字幕在线视频| 欧美在线观看视频| 久久久久中文字幕| 国产精品美乳在线观看| 国产成人精品电影久久久| 亚洲女人天堂色在线7777| 日韩精品中文字幕有码专区| 动漫精品一区二区| 精品五月天久久| 亚洲欧美国产精品va在线观看| 国内揄拍国内精品少妇国语| 91免费观看网站|