分享我第一次写的PHP+MYSQL分页类

原创 2004年09月28日 13:43:00

        之前看过几个分页类代码都比较长和复杂,愧于自己水平低下,没能看懂那些代码,加上发现当要在复合条件查询并分页显示数据的时候,那就很不好用了,于是想自己写一个。使用PHP五个月,对于类的概念和使用也才刚刚似懂非懂,这是本人第一次写的类——分页导航类,希望对新手,还有像我这样的PHPer有帮助!!

/*
_________________________________
 CLASS NAME:SHOWPAGE
_________________________________
 Copyright(c): ERLDY(稻草人)
 Author: Arvan  [E-mail:erldy@126.com QQ:103808353]
 Create date:   2004-09-27
 ________________________________
*/
 /*****
实例:
  $sql = "select count(*)as count from $tbl";
  $db->query($sql);
  $db->next_record();
  $count = $db->f(count);//记录总数
  
  $page = new ShowPage;
   $page->PageSize = 20;
  $page->Total = $count;
  $page->LinkAry = array(); //使用array("id"=>$id)这样的数组传递url变量
  $sql = "select * from $tbl order by sortid desc limit  ".$page->OffSet();
  $db->query($sql);
  $showpage = $page->ShowLink();

  
*****/
 class ShowPage {
  
 var $PageSize;     //每页显示的记录数
 
 var $Total;        //记录总数
 
 var $LinkAry;      //Url参数数组,对于复合条件查询分页显示情况非常好用
 
//取得总页数
 function PageCount() {
  $TotalPage = ($this->Total % $this->PageSize == 0) ? floor($this->Total / $this->PageSize) :  floor($this->Total / $this->PageSize)+1;
  return $TotalPage;
  }
//取得当前页
 function PageNum() {
  $page =  (isset( $_GET['page'])!="") ? $_GET['page'] :  $page = 1;
  return $page;
 }
//查询语句定位指针  
 function OffSet() {
  if ($this->PageNum() > $this->PageCount()) {
         //$this->PageNum = $this->PageCount();
         $pagemin = max(0,$this->Total - $this->PageSize - 1);
        }else if ($this->PageNum() == 1){
          $pagemin = 0;
         }else {
          $pagemin = min($this->Total - 1,$this->PageSize * ($this->PageNum() - 1));
           }
  return $pagemin . "," . $this->PageSize;
     }
//定位首页  
 function FristPage() {
  $Frist = ($this->PageNum() <= 1) ? "首页  " : "<a href=/"?page=1".$this->Url($this->LinkAry)."/">首页</a> ";
  return $Frist;
 }
//定位上一页
 function PrePage() {
  $prepage=$this->PageNum() - 1;
  $Previous = ($this->PageNum() >= 2) ? " <a href=/"?page=".$prepage.$this->Url($this->LinkAry)."/">上一页</a> " : "上一页 ";
  return $Previous;
 }
//定位下一页
 function NextPage() {
  $nextpage = $this->PageNum() + 1;
  $Next = ($this->PageNum() <= $this->PageCount()-1) ? " <a href=/"?page=".$nextpage.$this->Url($this->LinkAry)."/">下一页</a> " : "下一页 ";
  return $Next;
 }
//定位最后一页
 function LastPage() {
  $Last = ($this->PageNum() >= $this->PageCount()) ? "尾页  " : " <a href=/"?page=".$this->PageCount().$this->Url($this->LinkAry)."/">尾页</a> ";
  return $Last;
 }
//下拉跳转页面
 function JumpPage() {
  $Jump = " 当前第 <b>".$this->PageNum()."</b> 页  共 <b>".$this->PageCount()."</b> 页 跳到 <select name=page onchange=/"javascript:location=this.options[this.selectedIndex].value;/">";
  for ($i=1; $i<=$this->PageCount(); $i++) {
  if ($i==$this->PageNum())
   $Jump .= "<option value=/"?page=".$i.$this->Url($this->LinkAry)."/" selected>$i</option>";
  else
   $Jump .="<option value=/"?page=".$i.$this->Url($this->LinkAry)."/">$i</option> "; 
  }
     $Jump .= "</select> 页   <b>[".$this->PageSize."条/页]</b>";
  return $Jump;
 }
//URL参数处理
 function Url($ary) {
  $Linkstr = "";
  if (count($ary) > 0) {
   foreach ($ary as $key => $val) {
   $Linkstr .= "&".$key."=".$val;
   }
  }
  return $Linkstr;
 }
//生成导航条
 function ShowLink() {
  return $this->FristPage().$this->PrePage().$this->NextPage().$this->LastPage().$this->JumpPage();
 } 
 }

        这个类实现了分页的一般但比较全的功能,自我感觉结构非常简单,代码也很容易看懂,并且也比较好用!!

第一次写策划书的感想

今天接到我们技术部经理给的一个任务--写一个关于ppt设计大赛的企划书,之前没写过这个,所以一开始接到这个任务的时候还是有点儿蒙蒙 的感觉,于是就去网上搜一些关于企划书的资料,主要是想了解一下企划书里...
  • wangcola
  • wangcola
  • 2015年10月09日 21:54
  • 1218

第一次写博客,记录一下。

觉得做什么事情都需要坚持。 现在就开始博客之旅吧,记录自己的学习过程。 积少成多,坚持不懈...
  • baiyunsky2015
  • baiyunsky2015
  • 2015年04月02日 15:00
  • 135

第一次写学术论文无从下手怎么办

作者:欧阳笠 链接:https://www.zhihu.com/question/20829666/answer/20579444 来源:知乎 著作权归作者所有,转载请联系作者获得授权。 ...
  • xiaopihaierletian
  • xiaopihaierletian
  • 2016年11月22日 22:41
  • 342

编代码,第一次感觉累!

本人很喜欢编程,很喜欢解决问题,很喜欢思考问题,编程带给我很多乐趣和能量,喜欢挑战它们,更喜欢接触新的它们,喜欢我做的事儿,我从事的工作,不过最近的封闭开发,每天加班到很晚,周末的现在还在加班,还要持...
  • chenleixing
  • chenleixing
  • 2015年04月11日 13:49
  • 1607

第一次写程序

刚听到要写一个五子棋的程序,对于一个刚接触C的我简直是个挑战。但我用已看的知识写了一个效率极低的程序希望大家多原谅         思路:我用数组来储存棋子的位置 定义了一个15*15的数组,用数字2...
  • XIONG16
  • XIONG16
  • 2015年11月03日 15:50
  • 218

php+mysql分页类

拿去改改就能很好用的php+mysql分页类: 本程序文件对分页程序进行了封装
  • u011986449
  • u011986449
  • 2014年04月08日 21:00
  • 1652

我第一次写JAVA代码~

public class Hello{pubilic static void mian (String args[]) }System.out.println("你好很高兴学习JAVA"); } } ...
  • CrazyTao
  • CrazyTao
  • 2006年09月13日 00:51
  • 520

记第一次用C语言写代码的经历

刚上大学那会,代码对于我来说是一个神秘又陌生的词汇,从安卓手机出来那时候,我就深深被智能这个词汇 所着迷,智能手机的操作界面在我眼里不在只是一个图标,一个提示,那是一个世界,另一个多彩的世界,高中学业...
  • Hello_MrK
  • Hello_MrK
  • 2017年12月09日 00:50
  • 56

我第一次写博客

我刚学JAVA,以后每天是我学习JAVA的经历。把感悟写下。体会JAVA的精妙所在。 ...
  • lizhongqian
  • lizhongqian
  • 2006年12月24日 13:06
  • 445

第一次写我的blog

        中学时代,有写日记的习惯,那时候还没有internet,时过境迁,互联网已成为生活的一部分,很难想象,失去互联网,世界将会怎样?       经常登陆CSDN,只是收录“我的网摘”,全...
  • aqzhang
  • aqzhang
  • 2007年02月14日 11:08
  • 488
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:分享我第一次写的PHP+MYSQL分页类
举报原因:
原因补充:

(最多只允许输入30个字)