首页 > 语言 > 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()

输出内容和样式可以很方便的在类中调整,很简单,有兴趣可以研究一下

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表