php基于SQLite实现的分页功能示例


Posted in PHP onJune 21, 2017

本文实例讲述了php基于SQLite实现的分页功能。分享给大家供大家参考,具体如下:

这里操作数据库文件使用的是前面文章《PHP基于PDO实现的SQLite操作类【包含增删改查及事务等操作】》中的SQLite数据库操作类。废话不说,直接上代码:

<meta charset='utf-8'>
<?php
class SqlitePage{
  public function __construct()
  {
    $this->table_name='';
    $this->tj='';
    $this->page_size='';
    $this->current_page='';
    $this->total_page='';
    include_once 'sqlite_db.php';
    $this->db=new SqliteDB();//可以调用他的操作方法了
  }
  function entrance($table_name,$page_size,$tj='')//sql中不包含limit  page_size为每页显示条数
  {
    // 首先获取当前页
    // sql = "select * from tab where "+条件+" order by "+排序+" limit "+要显示多少条记录+" offset "+跳过多少条记录;
    $this->page_size=$page_size;
    $this->table_name=$table_name;
    $this->tj=$tj;
    $this->total_page=ceil($this->db->total($this->table_name,$this->tj)/$this->page_size);
    if (!isset($_GET['page'])) {
      $this->current_page=1;//如果没有page,则设置为默认第一页
    }
    else{
      $this->current_page=$_GET['page'];
    }
    if ($this->current_page>$this->total_page) {//当当前页数目大于总页数,则设置当前页数为总页数
      $this->current_page=$this->total_page;
    }
    if ($this->current_page<1) {//当当前页数目大于总页数,则设置当前页数为总页数
      $this->current_page=1;
    }
    $tj=$this->tj.' limit '.$this->page_size.' offset '.($this->current_page-1)*$this->page_size;
    $result=$this->db->query($this->table_name,$tj);
    return $result;
  }
  function page_bar()
  {
    $old_url = $_SERVER["REQUEST_URI"];
    $check = strpos($old_url, '?');
    $pre_urls='test';
    if ($check) {//如果urls中有?
      if(substr($old_url, $check+1) == '')
      { //有问号,但是后面没有跟任何参数
        $first_urls=$old_url.'page=1';//首页
        $pre_urls=$old_url.'page='.($this->current_page-1);//上一页;
        $next_urls=$old_url.'page='.($this->current_page+1);//下一页;
        $end_urls=$old_url.'page='.$this->total_page;//末页
      }
      else {//有问号,并且有参数
        if (isset($_GET['page'])) {//如果参数中包含page参数,则注销这个参数
          unset($_GET['page']);
          $old_url='http://'.$_SERVER['HTTP_HOST'].$_SERVER['PHP_SELF'].'?'.http_build_query($_GET);
        }
        $first_urls=$old_url.'&page=1';//首页
        $pre_urls=$old_url.'&page='.($this->current_page-1);//上一页;
        $next_urls=$old_url.'&page='.($this->current_page+1);//下一页;
        $end_urls=$old_url.'&page='.$this->total_page;//末页
      }
    }
    else{// 如果没有问号(也就是说后面没有任何参数,则直接跟)
      $first_urls=$old_url.'?page=1';
      $first_urls=$old_url.'?page=1';//首页
      $pre_urls=$old_url.'?page='.($this->current_page-1);//上一页;
      $next_urls=$old_url.'?page='.($this->current_page+1);//下一页;
      $end_urls=$old_url.'?page='.$this->total_page;//末页
    }
    // echo $this->table_name.'table_name';
    return '
    <div class="page">
      <a>【共'.$this->total_page.'页,第'.$this->current_page.'页】</a>
      <a href="'.$first_urls.'" rel="external nofollow" >首页</a>
      <a href="'.$pre_urls.'" rel="external nofollow" >上一页</a>
      <a href="'.$next_urls.'" rel="external nofollow" >下一页</a>
      <a href="'.$end_urls.'" rel="external nofollow" >末页</a>
    </div>
    ';
  }
  public function get_total_page()
  {
    return ceil($this->total_record/$this->page_size);
  }
}
// $page=new PrePage();
// $res=$page->entrance('log',10);
// echo "<hr />";
// foreach ($res as $key => $row) {
// echo $row['urls'].'<br />';
// }
// echo $page->page_bar();
?>

希望本文所述对大家PHP程序设计有所帮助。

PHP 相关文章推荐
在PHP中操作Excel实例代码
Apr 29 PHP
php判断文件上传类型及过滤不安全数据的方法
Dec 17 PHP
php cookie工作原理与实例详解
Jul 18 PHP
php并发加锁示例
Oct 17 PHP
php中的异常和错误浅析
May 03 PHP
Yii2数据库操作常用方法小结
May 04 PHP
PHP Socket网络操作类定义与用法示例
Aug 30 PHP
分析php://output和php://stdout的区别
May 06 PHP
ThinkPHP 3使用OSS的方法
Jul 19 PHP
PDO::rollBack讲解
Jan 29 PHP
php多进程应用场景实例详解
Jul 22 PHP
aec加密 php_php aes加密解密类(兼容php5、php7)
Mar 14 PHP
PHP面向对象之领域模型+数据映射器实例(分析)
Jun 21 #PHP
PHP基于PDO实现的SQLite操作类【包含增删改查及事务等操作】
Jun 21 #PHP
老生常谈PHP面向对象之标识映射
Jun 21 #PHP
PHP封装的PDO数据库操作类实例
Jun 21 #PHP
PHP基于ORM方式操作MySQL数据库实例
Jun 21 #PHP
php 猴子摘桃的算法
Jun 20 #PHP
详解php框架Yaf路由重写
Jun 20 #PHP
You might like
德生PL660的电路分析和打磨
2021/03/02 无线电
php curl基本操作详解
2013/07/23 PHP
基于Jquery的文字滚动跑马灯插件(一个页面多个滚动区)
2010/07/26 Javascript
jquery异步循环获取功能实现代码
2010/09/19 Javascript
js delete 用法(删除对象属性及变量)
2014/08/24 Javascript
javascript中call,apply,bind的用法对比分析
2015/02/12 Javascript
javascript制作游戏开发碰撞检测的封装代码
2015/03/31 Javascript
AngularJS控制器controller正确的通信的方法
2016/01/25 Javascript
仅30行代码实现Javascript中的MVC
2016/02/15 Javascript
利用AngularJs实现京东首页轮播图效果
2016/09/08 Javascript
JavaScript实现简单的日历效果
2016/09/25 Javascript
js滚轮事件兼容性问题需要注意哪些
2016/11/15 Javascript
JS实现购物车特效
2017/02/02 Javascript
原JS实现banner图的常用功能
2017/06/12 Javascript
详解JS中的柯里化(currying)
2017/08/17 Javascript
基于JavaScript实现抽奖系统
2018/01/16 Javascript
vue项目中公用footer组件底部位置的适配问题
2018/05/10 Javascript
vue组件中的数据传递方法
2018/05/14 Javascript
对 Vue-Router 进行单元测试的方法
2018/11/05 Javascript
bootstrap实现嵌套模态框的实例代码
2020/01/10 Javascript
vue 数据遍历筛选 过滤 排序的应用操作
2020/11/17 Javascript
基于Django的python验证码(实例讲解)
2017/10/23 Python
Python如何生成树形图案
2018/01/03 Python
详解python数据结构和算法
2019/04/18 Python
python django下载大的csv文件实现方法分析
2019/07/19 Python
python抓取多种类型的页面方法实例
2019/11/20 Python
python正则表达式的懒惰匹配和贪婪匹配说明
2020/07/13 Python
德国知名健康零食网上商店:Seeberger
2017/07/27 全球购物
荷兰超市:DEEN
2018/03/14 全球购物
医学生职业规划范文
2014/01/05 职场文书
小学校园之星事迹材料
2014/05/16 职场文书
新闻工作者先进事迹
2014/05/26 职场文书
王金山在党的群众路线教育实践活动总结大会上的讲话稿
2014/10/25 职场文书
工作年限证明模板
2015/06/15 职场文书
使用 DataAnt 监控 Apache APISIX的原理解析
2022/07/07 Servers
vue实现简易音乐播放器
2022/08/14 Vue.js