VB.net 2010 视频教程 VB.net 2010 视频教程 python基础视频教程
SQL Server 2008 视频教程 c#入门经典教程 Visual Basic从门到精通视频教程
当前位置:
首页 > PHP >
  • 一个功能比较高的分页类(for PHP5.x)

怕水平的不高,所以从来没有放过任何代码,这个类我已经用了很久,近来用面向对象方法重写,适用于PHP5.x,特地扔出,不怕见笑,希望抛砖引玉。

这个类适用于配合数据库查询分页,和数组分页,下面有使用方法。 

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

代码用法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()

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

出处:http://www.phpfensi.com/php/20131128/538.html


相关教程