当前位置: 首页 > news >正文

TP5分页类

图片描述

<?php
    class Page {
        public $page;   //当前页
        public $total; //总记录数
        public $listRows; //每页显示记录数
        private $uri;//动态url
        public $pageNum; //总页数
        private $listNum=6;//显示页码按钮数量
        public $render;//分页后的html模板
        public $data;//分页后渲染到模板的数据
        /*
         * 初始化分页数据
         *$sdata 待分页的数据
         * $listRows 每页记录数
         */
        public function __construct($sdata, $listRows=15){
            $this->total=count($sdata);
            $this->listRows=$listRows;
            $this->uri=$this->getUri();
            $this->page=!empty($_GET["page"]) ? $_GET["page"] : 1;
            $this->pageNum=ceil($this->total/$this->listRows);
            $this->render=$this->pageHtml();
            $this->data=array_slice($sdata,($this->page-1)*$this->listRows,$listRows);
            return $this->data;
        }

        //动态获取url
        private function getUri(){
            $url=$_SERVER["REQUEST_URI"].(strpos($_SERVER["REQUEST_URI"], '?')?'':"?");
            $parse=parse_url($url);

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

            return $url;
        }

        //首页
        private function first(){
            $html = "";
            if($this->page==1)
                $html.=" <a style='magin=10px;' class='current btn disabled'>首 页</a>";
            else
                $html.=" <a class='btn btn-primary-outline' href='{$this->uri}&page=1'>首 页</a>";

            return $html;
        }

        //上一页
        private function prev(){
            $html = "";
            if($this->page==1)
                $html.=" <a class='current btn disabled'>上一页</a>";
            else
                $html.=" <a class='btn btn-primary-outline' href='{$this->uri}&page=".($this->page-1)."'>上一页</a>";

            return $html;
        }

        //页码按钮
        private function pageList(){
            $linkPage="";

            $inum=floor($this->listNum/2);

            for($i=$this->page-$inum;$i<=$this->page+$inum;$i++){
                if($i<=0){
                    continue;
                }
                if($i>$this->pageNum){
                    continue;
                }
                if($i == $this->page){
                    $linkPage.=" <a class='current btn btn-secondary'>{$i}</a>";
                }else{
                    $linkPage.=" <a class='btn btn-primary-outline' href='{$this->uri}&page={$i}'>{$i}</a>";
                }
            }

            return $linkPage;
        }

        //下一页
        private function next(){
            $html = "";
            if($this->page==$this->pageNum)
                $html.=" <a class='current btn disabled'>下一页</a>";
            else
                $html.=" <a class='btn btn-primary-outline' href='{$this->uri}&page=".($this->page+1)."'>下一页</a>";

            return $html;
        }

        //尾页
        private function last(){
            $html = "";
            if($this->page==$this->pageNum)
                $html.=" <a class='current btn disabled'>尾 页</a>";
            else
                $html.=" <a class='btn btn-primary-outline' href='{$this->uri}&page=".($this->pageNum)."'>尾 页</a>";

            return $html;
        }

        //输入指定页码
        private function goPage(){
            return '  <input class="input-text" 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.'" style="width:52px"><input class="btn btn-secondary" type="button" value="GO" onclick="javascript:var page=(this.previousSibling.value>'.$this->pageNum.')?'.$this->pageNum.':this.previousSibling.value;location=\''.$this->uri.'&page=\'+page+\'\'">  ';
        }

        //选择指定页码
        function selectPage(){
            $inum=10;
            $location = $this->uri.'&page=';
            $selectPage ="<span class='va-m'>到第 </span> <span class='select-box' style='width:initial'><select class='select' name='topage' size='1' onchange='window.location=\"$location\"+this.value'>";

            for($i=$this->page-$inum;$i<=$this->page+$inum;$i++){
                if($i<=0){
                    continue;
                }
                if($i>$this->pageNum){
                    continue;
                }
                if($i == $this->page){
                    $selectPage .="<option value='$i' selected>$i</option>";
                }else{
                    $selectPage .="<option value='$i'>$i</option>";
                }
            }
            $selectPage .="</select></span> <span class='va-m'>页</span>";
            return $selectPage;
        }

        //组装分页的html模板
        function pageHtml(){
            $html  = "<div class='cl mt-20 text-c'>";
            // $html .= "<span class='pr-20 va-m'>共有<b>{$this->total}</b>条记录</span>";
            // $html .= "<span class='pr-20 va-m'>每页显示<b>{$this->listRows}</b>条</span>";
            // $html .= "<span class='pr-20 va-m'><b>当前{$this->page}/{$this->pageNum}</b>页</span>";

            $html .= $this->first();
            $html .= $this->prev();
            $html .= $this->pageList();
            $html .= $this->next();
            $html .= $this->last();
            $html .= $this->goPage();
            $html .= $this->selectPage();
            $html .= '</div>';

            return $html;
        }
    }

使用方法:在控制器中调用这个扩展类,new一个分页对象$p,并渲染到模板

       //$data:array,通过select()查询未分页的数据,不能是已经分页的对象
        $data = db('table_name')->select();
        //$data:未分页的数据  2:每页显示的记录数
        $p = new \Page($data,2);
        //把分页后的对象$p渲染到模板
        $this->assign([
            'p' => $p,
        ]);
        return $this->fetch();

使用方法:最后在模板中使用这个分页后的对象$p,通过$p->属性,获取对应的数据

//$p->data; //当前页数据
//$p->render; 分页html模板
//$p->page; //当前第几页
//$p->total; //总记录数
//$p->listRows; //每页显示记录数
//$p->pageNum; //总页数
//根据需要组装数据输出显示,例如:

//遍历数据
{volist name='$p->data' id='vo'}
//code...
{/volist}

//分页html模板输出
//默认已经载入h-ui框架css样式,否则需要重写css样式
{$p->render}

注意:支持URL模式,模块/控制器/操作?参数名=参数值&...

相关文章:

  • 新CSS伪类:focus-within
  • 如果一个人
  • xmemcached 0.60 优化过程
  • 生产环境硬件使用总结
  • xmemcached发布1.1.2 (权重、noreply、spring集成)
  • tomcat8.5报错
  • Clojure世界:利用HouseMD诊断clojure
  • pat解题报告【1082】
  • Java IO详解(七)------随机访问文件流
  • Spring+SpringMVC+MyBatis深入学习及搭建(三)——MyBatis全局配置文件解析
  • 硬链接和软链接
  • 【python自制】让大白成为你的个人助手!
  • java RabbitMQ
  • linux 21的用法
  • shell脚本编程30分钟入门上手
  • Android Volley源码解析
  • CSS3 变换
  • ECMAScript6(0):ES6简明参考手册
  • HTML5新特性总结
  • iOS编译提示和导航提示
  • JAVA 学习IO流
  • learning koa2.x
  • MySQL用户中的%到底包不包括localhost?
  • node入门
  • pdf文件如何在线转换为jpg图片
  • Python学习笔记 字符串拼接
  • 给第三方使用接口的 URL 签名实现
  • 回顾 Swift 多平台移植进度 #2
  • 极限编程 (Extreme Programming) - 发布计划 (Release Planning)
  • 删除表内多余的重复数据
  • 世界编程语言排行榜2008年06月(ActionScript 挺进20强)
  • 正则与JS中的正则
  • shell使用lftp连接ftp和sftp,并可以指定私钥
  • 宾利慕尚创始人典藏版国内首秀,2025年前实现全系车型电动化 | 2019上海车展 ...
  • ​如何防止网络攻击?
  • #Linux(权限管理)
  • #ubuntu# #git# repository git config --global --add safe.directory
  • #Z2294. 打印树的直径
  • (13)Hive调优——动态分区导致的小文件问题
  • (2/2) 为了理解 UWP 的启动流程,我从零开始创建了一个 UWP 程序
  • (20)目标检测算法之YOLOv5计算预选框、详解anchor计算
  • (HAL)STM32F103C6T8——软件模拟I2C驱动0.96寸OLED屏幕
  • (PHP)设置修改 Apache 文件根目录 (Document Root)(转帖)
  • (附源码)springboot优课在线教学系统 毕业设计 081251
  • (十六)串口UART
  • (续)使用Django搭建一个完整的项目(Centos7+Nginx)
  • (转) ns2/nam与nam实现相关的文件
  • (转)Oracle存储过程编写经验和优化措施
  • ***通过什么方式***网吧
  • .net core 3.0 linux,.NET Core 3.0 的新增功能
  • .net on S60 ---- Net60 1.1发布 支持VS2008以及新的特性
  • .NET Project Open Day(2011.11.13)
  • .NET/C# 使用 ConditionalWeakTable 附加字段(CLR 版本的附加属性,也可用用来当作弱引用字典 WeakDictionary)
  • .NET教程 - 字符串 编码 正则表达式(String Encoding Regular Express)
  • //解决validator验证插件多个name相同只验证第一的问题