一劳永逸 打造简单PHP分页函数

开发 后端
我们编写PHP分页函数的目的,就是为了减少在编码程序中的反复操作次数,已到达编码的高效性。下面我们将会给出具体的代码示例。

其实对于高级计算机语言来说,能够灵活的运用它们可以帮助我们完成许多需求。PHP语言也是如此,在不断的实践中积累经验,掌握编程技巧,可以为我们带来优质的代码程序。#t#

写列表性质的页面,几乎都要写上一段分页的程序。最近小阳终于决心一劳永逸——自定义一个分页函数,并保存在“pageft.php”文件里。要用 到分页的地方,就直接包含“pageft.php”文件,并调用这个函数就行了。小阳在编写这个函数时,尽量注意了程序的可移植性和易用性,下面就是小阳编写的PHP分页函数:
 

  1. < ?  
  2. //为了避免重复包含文件而造成错误,
    加了判断函数是否存在的条件:  
  3. if(!function_exists(pageft)){  
  4. //定义函数pageft(),三个参数的含义为:  
  5. //$totle:信息总数;  
  6. //$displaypg:每页显示信息数,这里设置为默认是20;  
  7. //$url:分页导航中的链接,除了加入不同的查询信息
    “page”外的部分都与这个URL相同。  
  8. //默认值本该设为本页URL(即$_SERVER["REQUEST_URI"])
    ,但设置默认值的右边只能为常量,所以该默认值设为空字符串
    ,在函数内部再设置为本页URL。  
  9. function pageft($totle,$displaypg=20,$url=”){  
  10. //定义几个全局变量:  
  11. //$page:当前页码;  
  12. //$firstcount:(数据库)查询的起始项;  
  13. //$pagenav:页面导航条代码,函数内部并没有将它输出;  
  14. //$_SERVER:读取本页URL“$_SERVER["REQUEST_URI"]”所必须。  
  15. global $page,$firstcount,$pagenav,$_SERVER;  
  16. //为使函数外部可以访问这里的“$displaypg”,
    将它也设为全局变量。注意一个变量重新定
    义为全局变量后,原值被覆盖,所以这里给它重新赋值。  
  17. $GLOBALS["displaypg"]=$displaypg;  
  18. if(!$page) $page=1;  
  19. //如果$url使用默认,即空值,则赋值为本页URL:  
  20. if(!$url){ $url=$_SERVER["REQUEST_URI"];}  
  21. //URL分析:  
  22. $parse_urlparse_url=parse_url($url);  
  23. $url_query=$parse_url["query"]; 
    //单独取出URL的查询字串  
  24. if($url_query){  
  25. //因为URL中可能包含了页码信息,我们要把它去掉,
    以便加入新的页码信息。  
  26. //这里用到了正则表达式,请参考“PHP中的正规表达式”
    (http://www.pconline.com.cn
    /pcedu/empolder/wz/php/10111/15058.html)  
  27. $url_query=ereg_replace(”(^|&)page=$page”,”",$url_query);  
  28.  
  29. //将处理后的URL的查询字串替换原来的URL的查询字串:  
  30. $url=str_replace($parse_url["query"],$url_query,$url);  
  31.  
  32. //在URL后加page查询信息,但待赋值:  
  33. if($url_query) $url.=”&page”; else $url.=”page”;  
  34. }else {  
  35. $url.=”?page”;  
  36. }  

 

PHP分页函数的页码计算:
 

  1. $lastpg=ceil($totle/$displaypg);   
  2. //***页,也是总页数  
  3. $page=min($lastpg,$page);  
  4. $prepg=$page-1;   
  5. //上一页  
  6. $nextpg=($page==$lastpg ? 0 : $page+1);   
  7. //下一页  
  8. $firstcount=($page-1)*$displaypg;  
  9. //开始分页导航条代码:  
  10. $pagenav=”显示第 < B>”.($totle?($firstcount+1):0).”
    < /B>-< B>”.min($firstcount+$displaypg,$totle).”
    < /B> 条记录,共 $totle 条记录< BR>”;  
  11. //如果只有一页则跳出函数:  
  12. if($lastpg<=1) return false;  
  13. $pagenav.=” < a href=’$url=1>首页< /a> “;  
  14. if($prepg) $pagenav.=” < a href=’$url=$prepg’>
    前页< /a> “; else $pagenav.=” 前页 “;  
  15. if($nextpg) $pagenav.=” < a href=’$url=$nextpg’>
    后页< /a> “; else $pagenav.=” 后页 “;  
  16. $pagenav.=” < a href=’$url=$lastpg’>尾页< /a> “;  
  17. //下拉跳转列表,循环列出所有页码:  
  18. $pagenav.=” 到第 < select name=’topage’ 
    size=’1′ onchange=’window.location=\”
    $
    url=\”+this.value’>\n”;  
  19. for($i=1;$i< =$lastpg;$i++){  
  20. if($i==$page) $pagenav.=”< option value=’$i’
     selected
    >$i< /option>\n”;  
  21. else $pagenav.=”< option value=’$i’>$i< /option>\n”;  
  22. }  
  23. $pagenav.=”< /select> 页,共 $lastpg 页”;  
  24. }  
  25. }  
  26. ?> 

 

好,PHP分页函数已经写好了,保存为“pageft.php”,要分页时就包含它并调用pageft()函数。不过它并没有输出任何东西,但产生几个全局变量供使用:$firstcount、$displaypg、$pagenav。

下面举例说明PHP分页函数的用法:

 

  1. < ?  
  2. //(前面程序略)  
  3. include(”pageft.php”);
     //包含“pageft.php”文件  
  4. //取得总信息数  
  5. $result=mysql_query(”select 
    * from mytable”);  
  6. $total=mysql_num_rows($result);  
  7. //调用pageft(),每页显示10条信息
    (使用默认的20时,可以省略此参数),
    使用本页URL(默认,所以省略掉)。  
  8. pageft($total,10);  
  9. //现在产生的全局变量就派上用场了:  
  10. $result=mysql_query(”select * 
    from mytable limit $firstcount,
    $displaypg “);  
  11. while($row=mysql_fetch_array($result)){  
  12. //(列表内容略)  
  13. }  
  14. //输出分页导航条代码:  
  15. echo $pagenav;  
  16. //(后面程序略)  
  17. ?> 

 

以上就是PHP分页函数的实现以及使用方法的代码示例。
 

责任编辑:曹凯 来源: yanzhilu.com
相关推荐

2023-10-12 10:22:14

JavaScripThis

2018-04-08 09:07:58

2009-10-12 14:06:05

U盘中毒

2011-08-11 13:11:24

准入控制

2023-10-25 14:47:08

架构设计人工智能

2023-10-18 10:42:44

WOT大会架构架构演进

2021-03-07 08:30:17

Github报错下载资源库

2021-12-07 07:58:33

个人图床工具

2022-01-17 09:58:29

自动化访问权限CIO

2016-10-18 13:58:15

2017-08-14 15:27:23

安卓单元测试代码测试

2023-11-13 10:55:09

MySQL数据库

2022-01-05 15:05:21

互联网跳槽大厂

2023-08-08 10:15:18

2022-04-15 08:07:21

ReactDiff算法

2021-12-03 12:15:01

QT中文乱码Windows

2023-02-24 12:52:11

智慧城市LoRaWAN

2019-12-30 15:42:07

光标Windows 10黑屏

2009-09-18 16:23:35

CCIE认证

2022-04-12 07:48:57

云技术SDN网络
点赞
收藏

51CTO技术栈公众号