转至繁体中文版     | 网站首页 | 图文教程 | 资源下载 | 站长博客 | 图片素材 | 武汉seo | 武汉网站优化 | 
最新公告:     敏韬网|教学资源学习资料永久免费分享站!  [mintao  2008年9月2日]        
您现在的位置: 学习笔记 >> 图文教程 >> 数据库 >> MySql >> 正文
php+mysql 分页显示函数         ★★★★

php+mysql 分页显示函数

作者:闵涛 文章来源:闵涛的学习笔记 点击数:1757 更新时间:2009/4/22 20:56:56

说明:
一、此分页函数一共有三个
  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> ";
     if($begin!=1) $nav .= "<span style=''''font-size=$font_size;''''>[</span><a href=''''?$param'''' title=''''第1

页''''><span style=''''font-size=$font_size;''''>第一页</span></a><span

style=''''font-size=$font_size;''''>]</spqn> ";
     if($page>1)   $nav .= "<span style=''''font-size=$font_size;''''>[</span><a href=''''?$param&page=".

($page-1)."'''' title=''''第".($page-1)."页''''><span style=''''font-size=$font_size;''''>上一页</span></a><span

style=''''font-size=$font_size;''''>]</span> ";
     $end = ($begin+$per_screen>$pages_num)?$pages_num+1:$begin+$per_screen;
     for($i=$begin; $i<$end; $i++) {
      $nav .=($page!=$i)?"<a href=''''?$param&page=$i'''' title=''''第{$i}页''''><span

style=''''font-size=$font_size;''''>$i</span></a> ":" <span

style=''''font-size=$font_size;color:red;''''>$i</span> ";
     }
     if($page<$pages_num)   $nav .= "<span style=''''font-size=$font_size;''''>[</span><a href=''''?

$param&page=".($page+1)."'''' title=''''第".($page+1)."页''''><span style=''''font-size=$font_size;''''>下一

页</span></a><span style=''''font-size=$font_size;''''>]</span> ";
     if($end!=$pages_num+1) $nav .= "<span style=''''font-size=$font_size;''''>[</span><a href=''''?

$param&page=$pages_num'''' title=''''第{$pages_num}页''''><span style=''''font-size=$font_size;''''>最后

页</span></a><span style=''''font-size=$font_size;''''>]</span> ";
    break;
   
    case 3:
       /* 样式3:  << 第一页 ... << 上一页 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;
     if($begin!=1) $nav .= "<span style=''''font-size=$font_size;''''>[</span><a href=''''?$param'''' title=''''第1

页''''><span style=''''font-size=$font_size;''''>第一页</span></a><span

style=''''font-size=$font_size;''''>]</spqn> ";
     if($page>1)   $nav .= "<span style=''''font-size=$font_size;''''>[</span><a href=''''?$param&page=".

($page-1)."'''' title=''''第".($page-1)."页''''><span style=''''font-size=$font_size;''''>上一页</span></a><span

style=''''font-size=$font_size;''''>]</span> ";
     $end = ($begin+$per_screen>$pages_num)?$pages_num+1:$begin+$per_screen;
     for($i=$begin; $i<$end; $i++) {
      $nav .=($page!=$i)?"<span style=''''font-size=$font_size;''''>[</span><a href=''''?$param&page=$i''''

title=''''第{$i}页''''><span style=''''font-size=$font_size;''''>$i</span></a><span

style=''''font-size=$font_size;''''>]</span> ":" <span style=''''font-size=$font_size;''''>[</span><span

style=''''font-size=$font_size;color:red;''''>$i</span><span style=''''font-size=$font_size;''''>]</span> ";
     }
     if($page<$pages_num)   $nav .= "<span style=''''font-size=$font_size;''''>[</span><a href=''''?

$param&page=".($page+1)."'''' title=''''第".($page+1)."页''''><span style=''''font-size=$font_size;''''>下一

页</span></a><span style=''''font-size=$font_size;''''>]</span> ";
     if($end!=$pages_num+1) $nav .= "<span style=''''font-size=$font_size;''''>[</span><a href=''''?

$param&page=$pages_num'''' title=''''第{$pages_num}页''''><span style=''''font-size=$font_size;''''>最后

页</span></a><span style=''''font-size=$font_size;''''>]</span> ";
    break;
    
    case 4:
     if ($page > 1) {
      $nav .= ''''<a href="?page=1&''''.$param.''''">&l

[1] [2]  下一页


[MySql]PHP存取 Mysql 数据乱码终极解决方案  [MySql]解决Table xxx is marked as crashed and should …
[MySql][MySQL]快速解决"is marked as crashed and shoul…  [MySql]MySQL DELETE语法用法详解
[MySql]mysql中时间日期格式化  [MySql]修改mysql导入文件大小限制
[其他]MySql常用命令大全  [Web开发]把ACCESS的数据导入到Mysql中的方法详解
[MySql]解决mysql 1040错误Too many connections的方法  [系统软件]利用crontab系统每天定时备份MySQL数据库
教程录入:mintao    责任编辑:mintao 
  • 上一篇教程:

  • 下一篇教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      注:本站部分文章源于互联网,版权归原作者所有!如有侵权,请原作者与本站联系,本站将立即删除! 本站文章除特别注明外均可转载,但需注明出处! [MinTao学以致用网]
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    同类栏目
    · Sql Server  · MySql
    · Access  · ORACLE
    · SyBase  · 其他
    更多内容
    热门推荐 更多内容
  • 没有教程
  • 赞助链接
    更多内容
    闵涛博文 更多关于武汉SEO的内容
    500 - 内部服务器错误。

    500 - 内部服务器错误。

    您查找的资源存在问题,因而无法显示。

    | 设为首页 |加入收藏 | 联系站长 | 友情链接 | 版权申明 | 广告服务
    MinTao学以致用网

    Copyright @ 2007-2012 敏韬网(敏而好学,文韬武略--MinTao.Net)(学习笔记) Inc All Rights Reserved.
    闵涛 投放广告、内容合作请Q我! E_mail:admin@mintao.net(欢迎提供学习资源)

    站长:MinTao ICP备案号:鄂ICP备11006601号-18

    闵涛站盟:医药大全-武穴网A打造BCD……
    咸宁网络警察报警平台