国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > 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()

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 浙江省| 镇坪县| 无极县| 遂川县| 洛南县| 盐边县| 和田市| 武邑县| 杂多县| 醴陵市| 平泉县| 伽师县| 五寨县| 呼伦贝尔市| 邵东县| 剑川县| 西和县| 基隆市| 勐海县| 什邡市| 庄河市| 吉木萨尔县| 观塘区| 定远县| 岳池县| 建水县| 襄汾县| 西青区| 丰城市| 上虞市| 高州市| 恩平市| 婺源县| 兰溪市| 高平市| 高台县| 泉州市| 昌宁县| 阳高县| 大理市| 开远市|