php实现分页功能的3种方法第3/3页

PHP实现分页功能的3种方法第3/3页的完整攻略

一、分页功能的基本原理

分页功能可以理解为将一份较大的数据集合分割成若干个小的数据块,并根据用户需求一块一块地输出,从而达到减轻服务器负担和提高用户访问速度的目的。其基本原理是结合 SQL 语句中的 LIMIT 和 OFFSET 命令实现。其中,LIMIT 表示要读取多少条数据,OFFSET表示从哪条数据开始读取。

二、方法三:封装分页类

使用 PHP封装分页类,使分页功能更易于组织和调用。步骤如下:

1. 创建统一的分页类

class Pager {
    private $total;                 //总记录数
    private $pagesize;              //每页显示多少条
    private $limitpage;             //总共多少页
    private $page;                  //当前是第几页
    private $nums;                  //显示多少个页码    
    private $url;                   //地址栏传递的整个URL字符串

    function __construct($total,$pagesize,$nums) {
        $this->total=$total;
        $this->pagesize=$pagesize;
        $this->nums=$nums;
        $this->limitpage=ceil($this->total/$this->pagesize);
        $this->page=empty($_GET['page'])?1:$_GET['page'];
        $this->url=$this->getUrl();
    }

2. 获取当前页码方法

    private function getUrl() {
        $url=$_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;
    }

    public function getPage() {
        $page=$this->page;
        if($page<1) {
            $page=1;
        }
        if($page>$this->limitpage) {
            $page=$this->limitpage;
        }
        return $page;
    }

3. SQL语句中用到的基本方法

    public function getLimit() {
        $offset=($this->getPage()-1)*$this->pagesize;
        return $offset.','.$this->pagesize;
    }

    public function getSql() {
        $offset=$this->getLimit();
        return "SELECT * FROM table1 LIMIT {$offset}";
    }

4. 显示页码方法

    public function getPages() {
        $pg=$this->nums%2==0?($this->nums/2):floor($this->nums/2)+1;
        $start=$this->getPage()-$pg+1;
        $start=$start<1?1:$start;
        $end=$start+$this->nums-1;
        $end=$end>$this->limitpage?$this->limitpage:$end;
        $url=$this->url."&page=";
        $pagestr='';
        if($this->page>1){
            $prev=$this->page-1;
            $pagestr.="<a href='{$url}1'>首页</a> ";
            $pagestr.="<a href='{$url}{$prev}'>上一页</a> ";
        }
        else {
            $pagestr.="<span class='disabled'>首页</span> ";
            $pagestr.="<span class='disabled'>上一页</span> ";
        }
        for($i=$start;$i<=$end;$i++) {
            if($i==$this->page) {
                $pagestr.="<span class='current'>{$i}</span> "; 
            }
            else {
                $pagestr.="<a href='{$url}{$i}'>{$i}</a> ";
            }
        }
        if($this->page<$this->limitpage) {
            $next=$this->page+1;
            $pagestr.="<a href='{$url}{$next}'>下一页</a> ";
            $pagestr.="<a href='{$url}{$this->limitpage}'>尾页</a> ";
        }
        else {
            $pagestr.="<span class='disabled'>下一页</span> ";
            $pagestr.="<span class='disabled'>尾页</span> ";
        }
        return $pagestr;
    }
}

5. 使用

使用封装好的分页类,只需要几行代码即可实现分页功能:

<?php 
    $dbh = new PDO("mysql:host=127.0.0.1;dbname=database", "username", "password");
    $total = $dbh->query('SELECT count(*) from table1')->fetchColumn();  //总记录数
    $pagesize = 10;     //每页显示多少条    
    $nums = 5;      //显示多少个页码 
    $pager = new Pager($total,$pagesize,$nums);      //初始化分页类 
    $limit = $pager->getLimit();  //获取SQL语句中要使用的OFFSET和LIMIT 
    $sql = 'SELECT * FROM table1 LIMIT '.$limit;  //组合SQL语句 
    $stmt = $dbh->query($sql);      //执行查询 
    while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
        echo $row['id'].' '.$row['col1'].' '.$row['col2'].'<br/>';
    }
    echo $pager->getPages();     //输出页码 
?> 

三、示例应用

示例1:分页数据展示

<?php 
    //连接数据库
    $dbh = new PDO("mysql:host=127.0.0.1;dbname=database", "username", "password");
    //获取总记录数
    $total = $dbh->query('SELECT count(*) from table1')->fetchColumn();
    //每页显示多少条    
    $pagesize = 10;     
    //显示多少个页码 
    $nums = 5;      
    //初始化分页类 
    $pager = new Pager($total,$pagesize,$nums);      
    //获取SQL语句中要使用的OFFSET和LIMIT 
    $limit = $pager->getLimit();  
    //组合SQL语句 
    $sql = 'SELECT * FROM table1 LIMIT '.$limit;  
    //执行查询 
    $stmt = $dbh->query($sql);
    //输出数据
    while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
        echo $row['id'].' '.$row['col1'].' '.$row['col2'].'<br/>';
    }
    //输出页码 
    echo $pager->getPages();    
?> 

示例2:分页数据展示(可根据名称和时间筛选)

<?php 
    //连接数据库
    $dbh = new PDO("mysql:host=127.0.0.1;dbname=database", "username", "password");
    //获取总记录数
    $name = isset($_GET['name']) ? trim($_GET['name']) : '';
    $start_time = isset($_GET['start_time']) ? strtotime(trim($_GET['start_time'])) : '';
    $end_time = isset($_GET['end_time']) ? strtotime(trim($_GET['end_time'])) : '';
    $where = '1=1';
    if($name) {
        $where .= " and name like '%".$name."%'";
    }
    if($start_time) {
        $where .= " and create_time >= '".$start_time."'";
    }
    if($end_time) {
        $where .= " and create_time <= '".$end_time."'";
    }   
    $total = $dbh->query('SELECT count(*) from table1 where '.$where)->fetchColumn();
    //每页显示多少条    
    $pagesize = 10;     
    //显示多少个页码 
    $nums = 5;      
    //初始化分页类 
    $pager = new Pager($total,$pagesize,$nums);      
    //获取SQL语句中要使用的OFFSET和LIMIT 
    $limit = $pager->getLimit();  
    //组合SQL语句 
    $sql = "SELECT * FROM table1 where ".$where." LIMIT ".$limit;  
    //执行查询 
    $stmt = $dbh->query($sql);
    //输出数据
    while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
        echo $row['id'].' '.$row['col1'].' '.$row['col2'].'<br/>';
    }
    //输出页码 
    echo $pager->getPages();    
?> 

以上两个示例分别是基本的分页数据展示和可根据名称和时间筛选的分页数据展示,通过封装分页类,可以在不同的应用场景中直接调用,代码更易于组织和管理,大大提高了开发效率。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:php实现分页功能的3种方法第3/3页 - Python技术站

(0)
上一篇 2023年5月27日
下一篇 2023年5月27日

相关文章

  • php字符串过滤与替换小结

    PHP字符串过滤与替换是网页开发中非常常用的一项操作,在用户输入的数据或系统输出的数据中,可能包含有一些不安全的内容,例如SQL注入、跨站脚本等,这时候我们需要对这些字符进行过滤或替换操作,从而达到保护用户安全信息的目的。 字符过滤 PHP中常见的字符过滤函数有htmlspecialchars和addslashes。 htmlspecialchars htm…

    PHP 2023年5月26日
    00
  • php使用array_chunk函数将一个数组分割成多个数组

    关于如何使用array_chunk函数将一个数组分割成多个数组,可以按照以下几个步骤进行: 1. 了解array_chunk函数 首先,需要了解array_chunk函数的基本用法。array_chunk函数的作用是将一个数组按照一定的大小,分割成若干个小的数组。其基本语法为: array array_chunk(array $array, int $siz…

    PHP 2023年5月26日
    00
  • PHP常用技巧总结(附函数代码)

    PHP常用技巧总结 一、字符串处理 1. 字符串反转 可以使用strrev()函数来反转字符串: $string = "Hello World!"; $reversed = strrev($string); echo $reversed; // 输出 "!dlroW olleH" 2. 字符串截取 我们常常需要从一个字…

    PHP 2023年5月24日
    00
  • PHP写日志的实现方法

    下面我来详细讲解”PHP写日志的实现方法”的完整攻略。 1. 什么是日志? 在计算机世界里,日志是记录事件的文件或条目。它可以为您提供有关您的应用程序的有价值的信息和统计数据,从而帮助您确定您的应用程序发生了什么情况。 2. 为什么需要PHP写日志? 在PHP开发中,写日志是非常重要的,因为您永远不知道在您的应用程序中会出现哪些问题。日志可以记录问题并帮助您…

    PHP 2023年5月27日
    00
  • php array_pop 删除数组最后一个元素实例

    当我们需要从数组的末尾删除一个元素时,可以使用php的array_pop函数。下面是详细的操作步骤: 函数介绍 array_pop array_pop() 函数删除并返回数组的最后一个值。 语法 array_pop(array) 参数 array:必需。规定要使用的数组。 返回值 成功返回数组的最后一个值,否则返回 NULL。 示例 示例一 $fruits …

    PHP 2023年5月26日
    00
  • php创建类并调用的实例方法

    下面是PHP创建类并调用实例方法的完整攻略,包括类的定义、对象的实例化和实例方法的调用。 1. 定义类 在PHP中,我们可以使用class关键字定义一个类,类名的首字母应该大写。 例如,定义一个Person类: class Person { // 在这里定义类的属性和方法 } 2. 定义属性和方法 在类的定义中,我们可以定义属性和方法。属性是类的变量,可以保…

    PHP 2023年5月25日
    00
  • PHP的cURL库功能简介 抓取网页、POST数据及其他

    PHP的cURL库功能简介 什么是cURL cURL是一种用来传输数据的工具和库。它支持各种各样的协议,包括HTTP、HTTPS、FTP、SMTP、POP3、LDAP、以及各种基于字节流的协议。 cURL在Linux和Unix系统中常常用来实现命令行下的文件传输。而PHP中提供了对cURL库的完整封装,简化了cURL库的使用,可以让我们方便地在PHP中使用c…

    PHP 2023年5月23日
    00
  • PHP生成静态HTML页面最简单方法示例

    下面是一份详细的攻略,包含了两条示例: PHP生成静态HTML页面最简单方法示例 为了将一个动态的 PHP 页面生成静态的 HTML 页面,我们需要使用一个名为ob_start()的 PHP 函数来缓存输出。然后,我们仅需将这个缓存的内容(即网页的 HTML 代码)写入到一个静态的 .html 文件中。 下面是实现这个过程的具体步骤: 开启 PHP 输出缓存…

    PHP 2023年5月27日
    00
合作推广
合作推广
分享本页
返回顶部