php+mysql 分页显示函数[1]

[入库:2005年8月19日] [更新:2007年3月24日]

本文简介:选择自 ipsearch2008 的 blog

说明:
一、此分页函数一共有三个
  1、function setparam($param1) //传递参数
  2、function page1($sqlstr)//执行query
  3、function page2($style)//分页的页码显示

二、分页页码显示一共有六种显示方式

   样式1:  第 1 2 3 4 5 6 7 8 9 页
   样式2:  共 记录 第一页 上一页 6 7 8 9 10 11 12 13 14 15 16 17 18 下一页 最后页
   样式3:  第一页 上一页 6 7 8 9 10 11 12 13 14 15 16 17 18 下一页 最后页
   样式4:  首页 | 上页 | 下页 | 末页
   样式5:  首页 | 上页 | 下页 | 末页 第 页 每页 条
   样式6:  第 页 每页 条
 
三、函数的使用

  把三个函数拷到你要使用的页面上。或者你建立一个function.php文件,把三个函数拷到function.php文件中,

在需要使用的时候require就可以了。

使用示例:
  <?
  $str="select * from table ";//不能用limit,table改为你自己的表名
  $temp=page1($str);
  ?>

  <?
  //这里设置你你要传递的参数
  $param1=array("a1","a2");//你可以加任意个你需要传递的参数,只要写上参数的名字。不要使

用$per_page,$page
  $param=setparam($param1);

  //这里显示你的分页导航条
  page2(n);//n可以为1-6的数值,也可以不设置。
  ?>

  while ($result=mysql_fetch_array($temp))
    {
    // 写你自己的显示语句。
    }
 

 
 四、函数如下 

 


//----------------------------------分页函数共三个-------------------//

// ipsearch 2003-08-01

//email ipsearch@sohu.com qq=153254


//-----------------------------------分页函数共三个-------------------//
function setparam($param1)
  {

// ipsearch 2003-08-01
//email ipsearch@sohu.com

 foreach( $param1 as $key)
  {
   global ${$key};
  $param .= urlencode($key).'='.urlencode(${$key}).'&';
  }
  return $param;
 }   


function page1($sqlstr)//分页的第一个处理程序,用来处理一系列环境变量.
   {

// ipsearch 2003-08-01
//email ipsearch@sohu.com
 global $rows_num,$page,$pages_num,$per_page,$rows_offset,$per_screen;
 
    if (!isset($page)) $page=1;//第几页
 if (!isset($rows_offse)) $rows_offse=2; //每页起始偏移
    if (!isset($per_screen)) $per_screen=10;//分页样式2 3 显示的页数
 if (!isset($per_page)) $per_page=30;//每页记录行数。
 $query=mysql_query($sqlstr);
    $rows_num=mysql_num_rows($query);
 $pages_num = ceil(($rows_num-$rows_offset)/$per_page);
 $str= $sqlstr." limit ".(($page-1)*$per_page+$rows_offset).", ".$per_page;
 return mysql_query($str);   
   }
function page2($style=2)
   {
    global $rows_num,$page,$pages_num,$per_page,$rows_offset,$param,$per_screen;
     $font_size="10pt"; 
 
          
    switch($style) {
     case 1:
     /* 样式1:  第 1 2 3 4 5 6 7 8 9 页*/
     for($i=1; $i<=$pages_num; $i++) {
         if (($i%26)==0) $nav .="<br>";
      if($i == $page) {
       $nav .= " <span style='font-size=$font_size;color=red;'>$i</span> ";
      }else {
       $nav .= " <a href=?page=$i&".$param."><span style='font-size=$font_size;'>$i</span></a> ";
      }
     }
     $nav = "<span style='font-size=$font_size;'>第</spqn> $nav <span style='font-size=$font_size;'>

页</span>";
     break;
    
      case 2:
       /* 样式2:  共 记录 第一页 上一页 6 7 8 9 10 11 12 13 14 15 16 17 18 下一页 最后页 */
     $mid = ceil(($per_screen+1)/2);
                 $nav = '';
                 if($page<=$mid ) {
      $begin = 1;
     }else if($page > $pages_num-$mid) {
      $begin = $pages_num-$per_screen+1;
     }else {
      $begin = $page-$mid+1;
     }
     if($begin<0) $begin = 1;
     $nav .="<span style='font-size=$font_size;'>共".$rows_num."记录</span> ";

本文关键:分页函数,php
 

本站最佳浏览方式为 分辨率 1024x768 IE 6.0(或更高版本的 IE浏览器)

go top