PHP原生分页原理(php分站原理)

网友投稿 279 2022-07-25

分页原理,会了的可以看第二条MySQL优化,不会的可以认真的阅读一下分页原理。

  class Page {

     private $total;   //总记录

     private $pagesize;  //每页显示多少条

     private $limit;     //limit

     private $page;      //当前页码

     private $pagenum;   //总页码

     private $url;      //地址

     private $bothnum;   //两边保持数字分页的量

   //构造方法初始化

   public function __construct($_total, $_pagesize) {

     $this->total = $_total ? $_total : 1;

     $this->pagesize = $_pagesize;

     $this->pagenum = ceil($this->total / $this->pagesize);

     $this->page = $this->setPage();

     $this->limit = "LIMIT ".($this->page-1)*$this->pagesize.",$this->pagesize";

     $this->url = $this->setUrl();

     $this->bothnum = 2;

   }

   //拦截器

   private function __get($_key) {

     return $this->$_key;

   }

   //获取当前页码

   private function setPage() {

     if (!empty($_GET['page'])) {

        if ($_GET['page'] > 0) {

          if ($_GET['page'] > $this->pagenum) {

             return $this->pagenum;

          } else {

             return $_GET['page'];

          }

        } else {

          return 1;

        }

     } else {

        return 1;

     }

   }

   //获取地址

   private function setUrl() {

     $_url = $_SERVER["REQUEST_URI"];

     $_par = parse_url($_url);

     if (isset($_par['query'])) {

        parse_str($_par['query'],$_query);

        unset($_query['page']);

        $_url = $_par['path'].'?'.http_build_query($_query);

     }

     return $_url;

   }   //数字目录

   private function pageList() {

     for ($i=$this->bothnum;$i>=1;$i--) {

      $_page = $this->page-$i;

      if ($_page < 1) continue;

        $_pagelist .= ' '.$_page.' ';

     }

     $_pagelist .= ' '.$this->page.' ';

     for ($i=1;$i<=$this->bothnum;$i++) {

      $_page = $this->page+$i;

        if ($_page > $this->pagenum) break;

        $_pagelist .= ' '.$_page.' ';

     }

     return $_pagelist;

   }

   //首页

   private function first() {

     if ($this->page > $this->bothnum+1) {

        return ' 1 ...';

     }

   }

   //上一页

   private function prev() {

     if ($this->page == 1) {

        return '上一页';

     }

     return ' 上一页 ';

   }

   //下一页

   private function next() {

     if ($this->page == $this->pagenum) {

        return '下一页';

     }

     return ' 下一页 ';

   }

   //尾页

   private function last() {

     if ($this->pagenum - $this->page > $this->bothnum) {

        return ' ...'.$this->pagenum.' ';

     }

   }

   //分页信息

   public function showpage() {

     $_page .= $this->first();

     $_page .= $this->pageList();

     $_page .= $this->last();

     $_page .= $this->prev();

     $_page .= $this->next();

     return $_page;

   }

 }

?>

分页样式如下图所示:

使用说明:

  $_page = new Page($_total,$_pagesize);

  //其中 $_total 是数据集的总条数,$_pagesize 是每页显示的数量.

?>

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:主从配置,读写分离是MySQL性能优化重点(mysql主从和读写分离)
下一篇:Mysql语句性能优化52条(mysql语句优化的几种方法)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~