zoukankan      html  css  js  c++  java
  • PHP实现的一分页工具类代码

    总的页数是一个长度一定的木块,这把尺子在这个木块上滑动,前提,尺子的两端不能超出木块:D。发现这么一来要做的事情就是去找这个尺子在木块上的起始点,根据用户给传进来的page变量。哈哈,关键代码下面:

     代码如下 复制代码
        /**
        * 把中间的看成一个可以滑动的固定长度的尺子
        *
        * 把$this->_totalShowPages 当成一个可以滑动的固定长度尺子,
        * 然后$this->_totalPages就是一个给定长度的木块,尺子在这个
        * 木块上滑动。情况两种:
        * 1. 尺子长度大于木块长度,那么就直接输出所有的页码;
        * 2. 尺子长度小于木块长度,那么就只用找到输出这个尺子长度页
        * 数的起始点——$start, $end;
        *www.111cn.Net

        * @Access protected
        * @Return void
        * @Exception none
        */
        protected function _getShowPageNumber()
        {
        $pageHtml = '';
        //找到$start点
        if($this->_curPage - 2 > 1) {
        $start = $this->_curPage - 2;
        } else {
        $start = 1;
        }
        //找到$end 点
        $end = $start + $this->_totalShowPages;
        if($end >= $this->_totalPages) {
        $end = $this->_totalPages;
        $start = $end - $this->_totalShowPages; //保证页面显示的长度为$this->_totalShowPages
        }
        if($start != 1) {
        $pageHtml .= $this->_getPageHtml(1);
        $preMore = $this->_curPage - $this->_totalShowPages;
        if($preMore < 1) {
        $preMore = 1;
        }
        $pageHtml .= $this->_getMorePageHtml($preMore);
        }
        for($page = $start; $page < $end; $page ++) {
        $pageHtml .= $this->_getPageHtml($page);
        }
        if($end != $this->_totalPages) {
        $pageHtml .= $this->_getMorePageHtml($end);
        }
        $pageHtml .= $this->_getNormalPageHtml($this->_totalPages);
        
        return $pageHtml;
        }
     

    第一种老想法的代码实现:

     代码如下 复制代码
        /**
        * 一步步的来
        *
        * @desc
        *
        * @Access protected
        * @Return void
        * @Exception none
        */
        protected function _getShowPageNumberTwo()
        {
        if($this->_curPage < $this->_totalShowPages) {
        for($page = 1; $page < $this->_totalShowPages; $page ++) {
        $pageHtml .= $this->_getPageHtml($page);
        }
        $pageHtml .= $this->_getMorePageHtml($this->_totalShowPages);
        $pageHtml .= $this->_getNormalPageHtml($this->_totalPages);
        } else {
        $pageHtml .= $this->_getNormalPageHtml(1);
        if($this->_curPage == $this->_totalShowPages) {
        $pageHtml .= $this->_getMorePageHtml(1);
        } else {
        $pageHtml .= $this->_getMorePageHtml($this->_curPage - $this->_totalShowPages);
        }
        if($this->_curPage + $this->_totalShowPages >= $this->_totalPages) {
        for($page = $this->_totalPages - $this->_totalShowPages; $page < = $this->_totalPages; $page ++) {
        $pageHtml .= $this->_getPageHtml($page);
        }
        } else {
        $start = $this->_curPage - 2;
        $end = $this->_curPage + $this->_totalShowPages - 2;
        for($page = $start; $page < $end; $page ++) {
        $pageHtml .= $this->_getPageHtml($page);
        }
        $pageHtml .= $this->_getMorePageHtml($this->_curPage + $this->_totalShowPages - 2);
        $pageHtml .= $this->_getNormalPageHtml($this->_totalPages);
        }
        }
        
        return $pageHtml;
        }
     

    示例图:

    类文件下载:HPage.php (等我这个小类库完成了再一起放上 :D)。

    更多详细内容请查看:http://www.111cn.net/phper/php/56745.htm

  • 相关阅读:
    #419 Div2 Problem B Karen and Coffee (统计区间重叠部分 && 前缀和)
    #418 Div2 Problem B An express train to reveries (构造 || 全排列序列特性)
    FZU 2203 单纵大法好 (二分 && 贪心)
    51Nod 1413 权势二进制 (思维)
    51Nod 1433 0和5 (数论 && 被9整除数的特点)
    POJ 2492 A Bug's Life (带权并查集 && 向量偏移)
    POJ 1456 Supermarket (贪心 && 并查集优化)
    POJ 1182 食物链 (带权并查集 && 向量偏移)
    #417 Div2 Problem B Sagheer, the Hausmeister (DFS && 枚举)
    #417 Div2 Problem C Sagheer and Nubian Market (二分 && std::accumulate)
  • 原文地址:https://www.cnblogs.com/alibai/p/3510054.html
Copyright © 2011-2022 走看看