完美的php分页类

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

<?php
  /**
    file: page.class.php
    完美分页类 Page
  */
  class Page {
    private $total;              //数据表中总记录数
    private $listRows;             //每页显示行数
    private $limit;              //SQL语句使用limit从句,限制获取记录个数
    private $uri;               //自动获取url的请求地址
    private $pageNum;             //总页数
    private $page;              //当前页
    private $config = array(
        'head' => "条记录",
        'prev' => "上一页",
        'next' => "下一页",
        'first'=> "首页",
        'last' => "末页"
      );
    //在分页信息中显示内容,可以自己通过set()方法设置
    private $listNum = 10;           //默认分页列表显示的个数

    /**
      构造方法,可以设置分页类的属性
      @param  int  $total    计算分页的总记录数
      @param  int  $listRows  可选的,设置每页需要显示的记录数,默认为25条
      @param  mixed  $query  可选的,为向目标页面传递参数,可以是数组,也可以是查询字符串格式
      @param   bool  $ord  可选的,默认值为true, 页面从第一页开始显示,false则为最后一页
     */
    public function __construct($total, $listRows=25, $query="", $ord=true){
      $this->total = $total;
      $this->listRows = $listRows;
      $this->uri = $this->getUri($query);
      $this->pageNum = ceil($this->total / $this->listRows);
      /*以下判断用来设置当前面*/
      if(!empty($_GET["page"])) {
        $page = $_GET["page"];
      }else{
        if($ord)
          $page = 1;
        else
          $page = $this->pageNum;
      }

      if($total > 0) {
        if(preg_match('/\D/', $page) ){
          $this->page = 1;
        }else{
          $this->page = $page;
        }
      }else{
        $this->page = 0;
      }

      $this->limit = "LIMIT ".$this->setLimit();
    }

    /**
      用于设置显示分页的信息,可以进行连贯操作
      @param  string  $param  是成员属性数组config的下标
      @param  string  $value  用于设置config下标对应的元素值
      @return  object      返回本对象自己$this, 用于连惯操作
     */
    function set($param, $value){
      if(array_key_exists($param, $this->config)){
        $this->config[$param] = $value;
      }
      return $this;
    }

    /* 不是直接去调用,通过该方法,可以使用在对象外部直接获取私有成员属性limit和page的值 */
    function __get($args){
      if($args == "limit" || $args == "page")
        return $this->$args;
      else
        return null;
    }

    /**
      按指定的格式输出分页
      @param  int  0-7的数字分别作为参数,用于自定义输出分页结构和调整结构的顺序,默认输出全部结构
      @return  string  分页信息内容
     */
    function fpage(){
      $arr = func_get_args();

      $html[0] = "<span class='p1'> 共<b> {$this->total} </b>{$this->config["head"]} </span>";
      $html[1] = " 本页 <b>".$this->disnum()."</b> 条 ";
      $html[2] = " 本页从 <b>{$this->start()}-{$this->end()}</b> 条 ";
      $html[3] = " <b>{$this->page}/{$this->pageNum}</b>页 ";
      $html[4] = $this->firstprev();
      $html[5] = $this->pageList();
      $html[6] = $this->nextlast();
      $html[7] = $this->goPage();

      $fpage = '<div style="font:12px \'\5B8B\4F53\',san-serif;">';
      if(count($arr) < 1)
        $arr = array(0, 1,2,3,4,5,6,7);

      for($i = 0; $i < count($arr); $i++)
        $fpage .= $html[$arr[$i]];

      $fpage .= '</div>';
      return $fpage;
    }

    /* 在对象内部使用的私有方法,*/
    private function setLimit(){
      if($this->page > 0)
        return ($this->page-1)*$this->listRows.", {$this->listRows}";
      else
        return 0;
    }

    /* 在对象内部使用的私有方法,用于自动获取访问的当前URL */
    private function getUri($query){
      $request_uri = $_SERVER["REQUEST_URI"];
      $url = strstr($request_uri,'?') ? $request_uri : $request_uri.'?';

      if(is_array($query))
        $url .= http_build_query($query);
      else if($query != "")
        $url .= "&".trim($query, "?&");

      $arr = parse_url($url);

      if(isset($arr["query"])){
        parse_str($arr["query"], $arrs);
        unset($arrs["page"]);
        $url = $arr["path"].'?'.http_build_query($arrs);
      }

      if(strstr($url, '?')) {
        if(substr($url, -1)!='?')
          $url = $url.'&';
      }else{
        $url = $url.'?';
      }

      return $url;
    }

    /* 在对象内部使用的私有方法,用于获取当前页开始的记录数 */
    private function start(){
      if($this->total == 0)
        return 0;
      else
        return ($this->page-1) * $this->listRows+1;
    }

    /* 在对象内部使用的私有方法,用于获取当前页结束的记录数 */
    private function end(){
      return min($this->page * $this->listRows, $this->total);
    }

    /* 在对象内部使用的私有方法,用于获取上一页和首页的操作信息 */
    private function firstprev(){
      if($this->page > 1) {
        $str = " <a href='{$this->uri}page=1'>{$this->config["first"]}</a> ";
        $str .= "<a href='{$this->uri}page=".($this->page-1)."'>{$this->config["prev"]}</a> ";
        return $str;
      }

    }

    /* 在对象内部使用的私有方法,用于获取页数列表信息 */
    private function pageList(){
      $linkPage = " <b>";

      $inum = floor($this->listNum/2);
      /*当前页前面的列表 */
      for($i = $inum; $i >= 1; $i--){
        $page = $this->page-$i;

        if($page >= 1)
          $linkPage .= "<a href='{$this->uri}page={$page}'>{$page}</a> ";
      }
      /*当前页的信息 */
      if($this->pageNum > 1)
        $linkPage .= "<span style='padding:1px 2px;background:#BBB;color:white'>{$this->page}</span> ";

      /*当前页后面的列表 */
      for($i=1; $i <= $inum; $i++){
        $page = $this->page+$i;
        if($page <= $this->pageNum)
          $linkPage .= "<a href='{$this->uri}page={$page}'>{$page}</a> ";
        else
          break;
      }
      $linkPage .= '</b>';
      return $linkPage;
    }

    /* 在对象内部使用的私有方法,获取下一页和尾页的操作信息 */
    private function nextlast(){
      if($this->page != $this->pageNum) {
        $str = " <a href='{$this->uri}page=".($this->page+1)."'>{$this->config["next"]}</a> ";
        $str .= " <a href='{$this->uri}page=".($this->pageNum)."'>{$this->config["last"]}</a> ";
        return $str;
      }
    }

    /* 在对象内部使用的私有方法,用于显示和处理表单跳转页面 */
    private function goPage(){
        if($this->pageNum > 1) {
        return ' <input style="width:20px;height:17px !important;height:18px;border:1px solid #CCCCCC;" type="text" onkeydown="javascript:if(event.keyCode==13){var page=(this.value>'.$this->pageNum.')?'.$this->pageNum.':this.value;location=\''.$this->uri.'page=\'+page+\'\'}" value="'.$this->page.'"><input style="cursor:pointer;width:25px;height:18px;border:1px solid #CCCCCC;" type="button" value="GO" onclick="javascript:var page=(this.previousSibling.value>'.$this->pageNum.')?'.$this->pageNum.':this.previousSibling.value;location=\''.$this->uri.'page=\'+page+\'\'"> ';
      }
    }

    /* 在对象内部使用的私有方法,用于获取本页显示的记录条数 */
    private function disnum(){
      if($this->total > 0){
        return $this->end()-$this->start()+1;
      }else{
        return 0;
      }
    }
  }

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

(0)

相关推荐

  • 一个简单且很好用的php分页类

    复制代码 代码如下: class Page {    // 分页栏每页显示的页数    public $rollPage = 6;    // 页数跳转时要带的参数    public $parameter  ;    // 默认列表每页显示行数    public $listRows = 20;    // 起始行数    public $firstRow ;    // 分页总页面数    protected $totalPages  ;    // 总行数    protected $to

  • 精美漂亮的php分页类代码

    这是一款简单,方便,功能齐全的分页类,可以根据自己的需要更改CSS样式文件以实现分页颜色的控制,利用php分页类,可以省去自己很多时间,只需要在分页的地方嵌入即可,下面看下使用方法: 1,在head里包含pager.css 复制代码 代码如下: <link href="pager.css" type="text/css" rel="stylesheet" /> 2,在分页处进行类的实例化: 复制代码 代码如下: <?php   

  • mysql+php分页类(已测)

    复制代码 代码如下: <?php       /*      mysql_pager.class.php 三个参数. mysql_query()的结果, url变量page, 您要的每页记录数      例子在这个文件底部      淡水河边整理测试      */ class mysql_pager {         // define properties         var $page;         var $result;         var $results_per_pa

  • 整合了前面的PHP数据库连接类~~做成一个分页类!

    不知道学PHP有没有前途~哎越写越没劲 <?php  Class createdb    //类的开始  {  var $db= "localhost";//数据库地址;  var $dbname = "root";//用户名;  var $dbpwd = "";//密码;  var $dbtable = "mysql";//使用的数据库  var $conn;    //数据库连接;  var $result;    

  • PHP通用分页类page.php[仿google分页]

    page.php 复制代码 代码如下: <?php /** ** 通用php分页类.(仿Google样式) ** 只需提供记录总数与每页显示数两个参数.(已附详细使用说明..) ** 无需指定URL,链接由程序生成.方便用于检索结果分页. ** 表单采用GET方法提交,可保证在诸如查询之,删除之类的操作时,不丢失URL参数 **/ class Pager{ //IE地址栏地址 var $url; //记录总条数 var $countall; //总页数 var $page; //分页数字链接 v

  • 两款万能的php分页类

    本文为大家分享个超级好用.万能的php分页类,具体的实现代码如下 第一款php分页类 <?php /* * To change this template, choose Tools | Templates * and open the template in the editor. */ /** * 分页类 * 使用方式: * $page = new Page(); * $page->init(1000, 20); * $page->setNotActiveTemplate('<

  • ThinkPHP分页类使用详解

    一.首先需要在MsgManage控制器中加入分页方法 知识点:1.count函数的试用2.Page类实例化操作及相关参数了解3.limit函数了用4.show函数了解 编辑文件admin/Lib/Action/MsgManageAction.class.php 代码如下: 复制代码 代码如下: class MsgManageAction extends CommonAction {    public function index(){     import('ORG.Util.Page'); 

  • PHP 分页类代码(简单好用型)第1/2页

    [code] <?php // pager类 $page = $_GET 当前1/2页 12下一页阅读全文

  • ThinkPHP使用心得分享-分页类Page的用法

    ThinkPHP中的Page类在ThinkPHP/Extend/Library/ORG/Util/Page.class.php中,所以使用前要引入Page类: 复制代码 代码如下: import('ORG.Util.Page'); //Page类的引入$db = M('abc');//实例化数据表abc$where = array('id'=>'2';);//条件语句$where,例表中字段id的值为2$count = $db->where($where)->count();//获取符合

  • 高效mongodb的php分页类(不使用skip)

    mongodb分页skip+limit分页要先查出所有结果再去跳过,这样如果查询页面越往后效率越低. 如果能够通过查询条件查出每页结果的最后一条记录,在用最后一条记录作为查询条件去查下一页,这样每次都查询页面size条记录,效率不会差. 具体代码如下:包含mongodb.class.php, page.class.php, test.php mongodb.class.php mongodb 操作类 复制代码 代码如下: <?php function show_error($message, $

随机推荐