PHP 自定义分页函数

   PHP 自定义分页函数

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

  //为了避免重复包含文件而造成错误,加了判断函数是否存在的条件:

  if(!function_exists(pageft)){

  //定义函数pageft(),三个参数的含义为:

  //$totle:信息总数;

  //$displaypg:每页显示信息数,这里设置为默认是20;

  //$url:分页导航中的链接,除了加入不同的查询信息“page”外的部分都与这个URL相同。

  //   默认值本该设为本页URL(即$_SERVER["REQUEST_URI"]),但设置默认值的右边只能为常量,所以该默认值设为空字符串,在函数内部再设置为本页URL。

  function pageft($totle,$displaypg=20,$url=''){

  //定义几个全局变量:

  //$page:当前页码;

  //$firstcount:(数据库)查询的起始项;

  //$pagenav:页面导航条代码,函数内部并没有将它输出;

  //$_SERVER:读取本页URL“$_SERVER["REQUEST_URI"]”所必须。

  global $page,$firstcount,$pagenav,$_SERVER;

  //为使函数外部可以访问这里的“$displaypg”,将它也设为全局变量。注意一个变量重新定义为全局变量后,原值被覆盖,所以这里给它重新赋值。

  $GLOBALS["displaypg"]=$displaypg;

  if(!$page) $page=1;

  //如果$url使用默认,即空值,则赋值为本页URL:

  if(!$url){ $url=$_SERVER["REQUEST_URI"];}

  //URL分析:

  $parse_url=parse_url($url);

  $url_query=$parse_url["query"]; //单独取出URL的查询字串

  if($url_query){

  //因为URL中可能包含了页码信息,我们要把它去掉,以便加入新的页码信息。

  //这里用到了正则表达式,请参考“PHP中的正规表达式”(http://www.pconline.com.cn/pcedu/empolder/wz/php/10111/15058.html)

  $url_query=ereg_replace("(^|&)page=$page","",$url_query);

  //将处理后的URL的查询字串替换原来的URL的查询字串:

  $url=str_replace($parse_url["query"],$url_query,$url);

  //在URL后加page查询信息,但待赋值:

  if($url_query) $url.="&page"; else $url.="page";

  }else {

  $url.="?page";

  }

  页码计算:

  $lastpg=ceil($totle/$displaypg); //最后页,也是总页数

  $page=min($lastpg,$page);

  $prepg=$page-1; //上一页

  $nextpg=($page==$lastpg ? 0 : $page+1); //下一页

  $firstcount=($page-1)*$displaypg;

  //开始分页导航条代码:

  $pagenav="显示第 ".($totle?($firstcount+1):0)."-".min($firstcount+$displaypg,$totle)." 条记录,共 $totle 条记录

  ";

  //如果只有一页则跳出函数:

  if($lastpg<=1) return false;

  $pagenav.=" 首页 ";

  if($prepg) $pagenav.=" 前页 "; else $pagenav.=" 前页 ";

  if($nextpg) $pagenav.=" 后页 "; else $pagenav.=" 后页 ";

  $pagenav.=" 尾页 ";

  //下拉跳转列表,循环列出所有页码:

  $pagenav.=" 到第 n";   for($i=1;$i<=$lastpg;$i++){   if($i==$page) $pagenav.="$in";   else $pagenav.="$in";   }   $pagenav.=" 页,共 $lastpg 页";

  }

  }

  ?>


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

  //(前面程序略)

  include("pageft.php"); //包含“pageft.php”文件

  //取得总信息数

  $result=mysql_query("select * from mytable");

  $total=mysql_num_rows($result);

  //调用pageft(),每页显示10条信息(使用默认的20时,可以省略此参数),使用本页URL(默认,所以省略掉)。

  pageft($total,10);

  //现在产生的全局变量就派上用场了:

  $result=mysql_query("select * from mytable limit $firstcount,$displaypg ");

  while($row=mysql_fetch_array($result)){

  //(列表内容略)

  }

  //输出分页导航条代码:

  echo $pagenav;

  //(后面程序略)

  ?>

时间: 2024-12-31 10:36:09

PHP 自定义分页函数的相关文章

emlog修改分页样式(分页函数)方法总结

不修改内核实现emlog分页的上页.下页效果 1.先在你使用的模板的module.php文件中增加自定义的分页函数,代码如下:  代码如下 复制代码 <?php //blog:自定义分页函数 function my_page($count, $perlogs, $page, $url, $anchor = '') {  $pnums = @ceil($count / $perlogs);  $re = '';  $urlHome = preg_replace("|[?&/][^./

自定义PHP分页函数

分页|函数 ??每次编写列表性质的页面,几乎都要写上一段分页的程序.最近小阳终于决心一劳永逸??自定义一个分页函数,并保存在"pageft.php"文件里.要用到分页的地方,就直接包含"pageft.php"文件,并调用这个函数就行了.小阳在编写这个函数时,尽量注意了程序的可移植性和易用性,下面就是小阳编写的函数: ??好,分页函数已经写好了,保存为"pageft.php",要分页时就包含它并调用pageft()函数.不过它并没有输出任何东西,但

自定义PHP分页函数_php基础

每次编写列表性质的页面,几乎都要写上一段分页的程序.最近小阳终于决心一劳永逸--自定义一个分页函数,并保存在"pageft.php"文件里.要用到分页的地方,就直接包含"pageft.php"文件,并调用这个函数就行了.小阳在编写这个函数时,尽量注意了程序的可移植性和易用性,下面就是小阳编写的函数: 好,分页函数已经写好了,保存为"pageft.php",要分页时就包含它并调用pageft()函数.不过它并没有输出任何东西,但产生几个全局

PHP封装分页函数实现文本分页和数字分页_php实例

最近,在项目中要用到分页.分页功能是经常使用的一个功能,所以,对其以函数形式进行了封装. // 分页分装/*** $pageType 分页类型 1是数字分页 2是文本分页* 可以将$pageTotal,$page,$total等数据作为参数传递,或者在paging作为全局变量(推荐)*/function paging($pageType){ global $pageTotal,$page,$total; if($pageType == 1) { echo '<div id="pagenum

php自定义分页类完整实例_php技巧

本文实例讲述了php自定义分页类.分享给大家供大家参考,具体如下: <?php header("Content-type:text/html;Charset=utf-8"); class SubPages{ private $each_disNums;//每页显示的条目数 private $nums;//总条目数 private $current_page;//当前被选中的页 private $sub_pages;//每次显示的页数 private $pageNums;//总页数

Laravel 5.1 分页功能实现及自定义分页样式的例子

Laravel还为分页提供了多种实现方式,既可以基于查询构建器实现分页,也可以基于Eloquent模型进行分页,最终生成的分页视图还兼容Bootstrap CSS样式.讲到这里,估计很多人已经跃跃欲试了,想要迫不及待的看看Laravel到底是如何实现分页的,下面让我们一一道来: 1.使用查询构建器实现分页 简单分页 我们可以在查询构建器上简单调用simplePaginate方法,从而实现类似WordPress默认分页的样式(上一页.下一页这种简单的分页链接): class PostControl

GridView自定义分页的四种存储过程_MsSql

1. 为什么不使用GridView的默认分页功能 首先要说说为什么不用GridView的默认的分页功能,GridView控件并非真正知道如何获得一个新页面,它只是请求绑定的数据源控件返回适合规定页面的行,分页最终是由数据源控件完成.当我们使用SqlDataSource或使用以上的代码处理分页时.每次这个页面被请求或者回发时,所有和这个SELECT语句匹配的记录都被读取并存储到一个内部的DataSet中,但只显示适合当前页面大小的记录数.也就是说有可能使用Select语句返回1000000条记录,

GridView自定义分页的四种存储过程

1. 为什么不使用GridView的默认分页功能 首先要说说为什么不用GridView的默认的分页功能,GridView控件并非真正知道如何获得一个新页面,它只是请求绑定的数据源控件返回适合规定页面的行,分页最终是由数据源控件完成.当我们使用SqlDataSource或使用以上的代码处理分页时.每次这个页面被请求或者回发时,所有和这个SELECT语句匹配的记录都被读取并存储到一个内部的DataSet中,但只显示适合当前页面大小的记录数.也就是说有可能使用Select语句返回1000000条记录,

php分页函数示例代码分享

 这篇文章主要介绍了php分页函数示例代码,需要的朋友可以参考下 分享一例php分页函数代码,用此函数实现分页代码很不错.   代码,php分页函数.  代码如下: <?php /* * Created on 2011-07-28 * Author : LKK , http://lianq.net * 使用方法: require_once('mypage.php'); $result=mysql_query("select * from mytable", $myconn); $