香港高速VIP云机房火爆上线啦!无需备案,开通即用!配套《巅云自助建站系统3.0》将带给您飞一般的可视化拖拽建站体验,欢迎免费体验。

建站专题

php显示页码分页类的封装

一佰互联网站开发设计(www.yinxi.net) 发布日期 2019-04-26 09:01:53 浏览数: 60

本文实例为大家分享了php封装显示页码的分页类,供大家参考,具体内容如下

一、代码

conn.php

<?php  class Mysql{   public function __construct(){    $this->connect();   }   public function connect(){    $conn=mysql_pconnect("localhost","root","root") or die("Connect MySQL False");    mysql_select_db("db_database20",$conn) or die("Connect DB False");    mysql_query("SET NAMES utf8");   }  } ?> 

index.php

<link rel="stylesheet" type="text/css" href="css/style.css" rel="external nofollow" > <?php  include_once("conn.php");//包含conn.php文件  class Page extends Mysql{//创建Page类并继承Mysql类   private $pagesize;//每页显示的记录数   private $page;//当前是第几页   private $pages;//总页数   private $total;//查询的总记录数   private $pagelen;//显示的页码数   private $pageoffset;//页码的偏移量   private $table;//欲查询的表名   function __construct($pagesize,$pagelen,$table){   if($_GET["page"]=="" || $_GET["page"]<0){//判断地址栏参数page是否有值    $this->page=1;//当前页定义为1   }else{    $this->page=$_GET["page"];//当前页为地址栏参数的值   }   $this->pagesize=$pagesize;   $this->pagelen=$pagelen;   $this->table=$table;   new Mysql();//实例化Mysql类   $sql=mysql_query("select * from $this->table");//查询表中的记录   $this->total=mysql_num_rows($sql);//获得查询的总记录数   $this->pages=ceil($this->total/$this->pagesize);//计算总页数   $this->pageoffset=($this->pagelen-1)/2;//计算页码偏移量   }   function sel(){   $sql=mysql_query("select * from $this->table limit ".($this->page-1)*$this->pagesize.",".$this->pagesize);//查询当前页显示的记录   return $sql;//返回查询结果   }   function myPage(){   $message="第".$this->page."页/共".$this->pages."页   ";//输出当前第几页,共几页   if($this->page==1){//如果当前页是1    $message.="首页 上一页   ";//输出没有链接的文字   }else{    $message.="<a href="".$_SERVER["PHP_SELF"]."?page=1">首页</a> ";//输出有链接的文字    $message.="<a href="".$_SERVER["PHP_SELF"]."?page=".($this->page-1)."">上一页</a>  ";//输出有链接的文字   }   if($this->page<=$this->pageoffset){//如果当前页小于页码的偏移量    $minpage=1;//显示的最小页数为1    $maxpage=$this->pagelen;//显示的最大页数为页码的值   }elseif($this->page>$this->pages-$this->pageoffset){//如果当前页大于总页数减去页码的偏移量    $minpage=$this->pages-$this->pagelen+1;//显示的最小页数为总页数减去页码数再加上1    $maxpage=$this->pages;//显示的最大页数为总页数   }else{    $minpage=$this->page-$this->pageoffset;//显示的最小页数为当前页数减去页码的偏移量    $maxpage=$this->page+$this->pageoffset;//显示的最大页数为当前页数加上页码的偏移量   }   for($i=$minpage;$i<=$maxpage;$i++){//循环输出数字页码数    if($i==$this->page){    $message.=$i."";//输出没有链接的数字    }else{    $message.="<a id="num" href="".$_SERVER["PHP_SELF"]."?page=".$i."">".$i."</a>";//输出有链接的数字    }   }   if($this->page==$this->pages){//如果当前页等于最大页数    $message.="  下一页 尾页";//显示没有链接的文字   }else{    $message.="  <a href="".$_SERVER["PHP_SELF"]."?page=".($this->page+1)."">下一页</a> ";//显示有链接的文字    $message.="<a href="".$_SERVER["PHP_SELF"]."?page=".$this->pages."">尾页</a>";//显示有链接的文字   }   return $message;//返回变量的值   }  } ?> <table border="1" cellpadding="1" cellspacing="1" bordercolor="#FFFFFF" bgcolor="#FF0000">  <tr>  <td style="padding-left:3px; padding-right:3px; padding-top:3px; padding-bottom:3px;" bgcolor="#FFFFFF">ID:</td>  <td style="padding-left:3px; padding-right:3px; padding-top:3px; padding-bottom:3px;" bgcolor="#FFFFFF">标题</td>  <td style="padding-left:3px; padding-right:3px; padding-top:3px; padding-bottom:3px;" bgcolor="#FFFFFF">内容</td>  <td style="padding-left:3px; padding-right:3px; padding-top:3px; padding-bottom:3px;" bgcolor="#FFFFFF">时间</td>  </tr> <?php  $p=new Page("3","3","tb_demo01");  $rs=$p->sel();  while($rst=mysql_fetch_row($rs)){ ?>  <tr>  <td style="padding-left:3px; padding-right:3px; padding-top:3px; padding-bottom:3px;" bgcolor="#FFFFFF"><?php echo $rst[0] ?></td>  <td style="padding-left:3px; padding-right:3px; padding-top:3px; padding-bottom:3px;" bgcolor="#FFFFFF"><?php echo $rst[1] ?></td>  <td style="padding-left:3px; padding-right:3px; padding-top:3px; padding-bottom:3px;" bgcolor="#FFFFFF"><?php echo $rst[2] ?></td>  <td style="padding-left:3px; padding-right:3px; padding-top:3px; padding-bottom:3px;" bgcolor="#FFFFFF"><?php echo $rst[3] ?></td>  </tr> <?php }?> </table> <?php  echo $p->myPage(); ?> 

二、运行结果

 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持网页设计。

一佰互联是全国知名建站品牌服务商,我们有九年网站建设、网站制作、网页设计、php开发和域名注册及虚拟主机服务经验,提供的自助建站服务更是全国有名。近年来还整合团队优势自主开发了可视化多用户”巅云建站系统“3.0平台版,拖拽排版网站制作设计,轻松实现pc站、手机微网站、小程序、APP一体化全网营销网站建设 ,已成功的为全国上百家网络公司提供自助建站平台搭建服务。

相关新闻more

05
04月
网站优化中长尾关键词布局非常重要,网站长尾关

简介:长尾关键词布局非常重要 因为涉及到网站后期优化效果。布局长尾词的第一点是挖掘和筛选长尾词,然后根据长尾词的竞争度以及相关性布局在网站的... >>详情

22
11月
站虚拟空间是什么?与网站空间的区别

站虚拟空间是什么?与网站空间的区别 什么是虚拟空间?实际上虚拟空间就是网站空间,所谓虚拟并非不存而是空间存放在世界某个机房。只是用户还要通过... >>详情

26
03月
如何制作群发邮件而不被屏蔽?

简介:提到群发邮件,许多企业都是又爱又恨,恨得是发出去如同沉入大海般了无音讯,爱的当然是营销成本低,单次传播覆盖广,效果可监控。那么如何群发... >>详情

12
05月
专业网站建设实现利益最大化

专业网站建设是一个专业的平台,可以给人们提供很多的服务,并且有拥有很多专业的技术人员,而且专业网站建设实现利益最大化,人们可以利用这个平台可... >>详情

营业执照. cdn加速服务 备案系统认证 网络安全协会 我们的支付方式AAA认证
上海 北京 深圳 广州 天津 杭州 南京 武汉 成都 沈阳 大连 长沙 济南 青岛 苏州 福州 无锡 哈尔滨 宁波 重庆 大庆 厦门 西安 长春 珠海 郑州 海口 昆明 太原 石家庄 温州 合肥 乌鲁木齐 南宁 南通 合肥 兰州 呼和浩特 贵阳 烟台 秦皇岛 包头 唐山 银川 汕头 连云港 威海 西宁 湛江 北海 万州 涪陵 长寿 黔江 永川 丰都 忠县 江津 南川 开县 云阳 万盛 梁平 垫江 巫山 城口 建站宝盒 免费建站 门户网站建设 微信网站 手机网站 门户网站制作

7x24小时服务电话:18581389571 传真:023-85725751 免费建站交流群:236412099 139947842(自助建站交流) E-Mail:post@yinxi.net 网站投诉:
重庆楚捷科技有限公司 一佰互联©版权所有 自助建站(www.yinxi.net,Inc.) 2001-2020 All Rights Reserved 本站程序受法律保护,网站法律顾问:ITLAW-庄毅雄律师
中华人民共和国信息产业部网站备案号:渝ICP备12000592号