侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

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

php  /  管理员 发布于 7年前   192

直接上代码,希望大家仔细阅读。

方法一:讲sql查询进行分页进行,需要调用几个函数,具体见脚本:
1.pager.class.php

_conn === false || !is_resource($this->_conn)) {       warningLog(__METHOD__ . ': query sql with no connection', true);      return false;      }    $this->_query_id = @mysql_query($query, $this->_conn);    if ($this->_query_id === false) {    $this->_errstr = @mysql_error();    $ret = false;     } else {    $this->_errstr = 'SUCCESS';    $ret = $this->_query_id;      }    }     $msg = ($ret === false) ? 'false' : strval($ret);     debugLog(__METHOD__.": [$msg] returned for sql query [$query]");    return $ret;    }function __construct($sql,$page_size) {      $result = mysql_query($sql);      $datanum = mysql_num_rows($result);      $this->sql=$sql;      $this->datanum=$datanum;      $this->page_size=$page_size;    }    //当前页数    public function page_id() {      if($_SERVER['QUERY_STRING'] == ""){        return 1;      }elseif(substr_count($_SERVER['QUERY_STRING'],"page_id=") == 0){        return 1;      }else{        return intval(substr($_SERVER['QUERY_STRING'],8));      }    }    //剩余url值    public function url() {      if($_SERVER['QUERY_STRING'] == ""){        return "";      }elseif(substr_count($_SERVER['QUERY_STRING'],"page_id=") == 0){        return "&".$_SERVER['QUERY_STRING'];      }else{        return str_replace("page_id=".$this->page_id(),"",$_SERVER['QUERY_STRING']);      }    }    //总页数    public function page_num() {      if($this->datanum == 0){        return 1;      }else{        return ceil($this->datanum/$this->page_size);      }    }//数据库查询的偏移量    public function start() {      return ($this->page_id()-1)*$this->page_size;    }    //数据输出    public function sqlquery() {      return $this->sql." limit ".$this->start().",".$this->page_size;    }    //获取当前文件名    private function php_self() {      return $_SERVER['PHP_SELF'];    }    //上一页    private function pre_page() {      if ($this->page_id() == 1) { //页数等于1        return "php_self()."?page_id=1".$this->url().">上一页 ";      }elseif ($this->page_id() != 1) { //页数不等于1        return "php_self()."?page_id=".($this->page_id()-1).$this->url().">上一页 ";      }    }    //显示分页    private function display_page() {      $display_page = "";      if($this->page_num() <= 10){ //小于10页        for ($i=1;$i<=$this->page_num();$i++) //循环显示出页面          $display_page .= "php_self()."?page_id=".$i.$this->url().">".$i." ";          return $display_page;      }elseif($this->page_num() > 10){ //大于10页        if($this->page_id() <= 6){          for ($i=1;$i<=10;$i++) //循环显示出页面$display_page .= "php_self()."?page_id=".$i.$this->url().">".$i." ";return $display_page;        }elseif(($this->page_id() > 6) && ($this->page_num()-$this->page_id() >= 4)){          for ($i=$this->page_id()-5;$i<=$this->page_id()+4;$i++) //循环显示出页面$display_page .= "php_self()."?page_id=".$i.$this->url().">".$i." "; return $display_page;        }elseif(($this->page_id() > 6) && ($this->page_num()-$this->page_id() < 4)){          for ($i=$this->page_num()-9;$i<=$this->page_num();$i++) //循环显示出页面$display_page .= "php_self()."?page_id=".$i.$this->url().">".$i." ";return $display_page;        }      }    }    //下一页    private function next_page() {      if ($this->page_id() < $this->page_num()) { //页数小于总页数        return "php_self()."?page_id=".($this->page_id()+1).$this->url().">下一页 ";      }elseif ($this->page_id() == $this->page_num()) { //页数等于总页数        return "php_self()."?page_id=".$this->page_num().$this->url().">下一页 ";      }    }    // 设置分页信息    public function set_page_info() {      $page_info = "共".$this->datanum."条 ";      $page_info .= "php_self()."?page_id=1".$this->url().">首页 ";      $page_info .= $this->pre_page();      $page_info .= $this->display_page();      $page_info .= $this->next_page();      $page_info .= "php_self()."?page_id=".$this->page_num().$this->url().">尾页 ";      $page_info .= "第".$this->page_id()."/".$this->page_num()."页";      return $page_info;    }  }?>

2.脚本2:

sqlquery());while($info = mysql_fetch_array($result,MYSQL_ASSOC)){  // while($info = mysql_fetch_array($res_1, MYSQL_ASSOC)){  echo $info["word"]."
"; } // 页码索引条 echo $page->set_page_info();?>

方法二:使用ajax的方法
1、首先了解SQL语句中的limit用法

SELECT * FROM table …… limit 开始位置 , 操作条数 (其中开始位置是从0开始的)

例子
取前20条记录:SELECT * FROM table …… limit   0 , 20
从第11条开始取20条记录:SELECT * FROM table …… limit   10 , 20 
LIMIT n 等价于 LIMIT 0,n。
如select * from table LIMIT 5; //返回前5行,和 select * from table LIMIT 0,5一样 
2、分页原理

 所谓分页显示,也就是讲数据库中的结果集,一段一段显示出来
怎么分段,当前在第几段 (每页有几条,当前再第几页)
前10条记录:select * from table limit 0,10
第11至20条记录:select * from table limit 10,10
第21至30条记录:select * from table limit 20,10
分页公式:
(当前页数 - 1 )X 每页条数 , 每页条数

Select * from table limit ($Page- 1) * $PageSize, $PageSize 

3、$_SERVER["REQUEST_URI"]函数
预定义服务器变量的一种,所有$_SERVER开头的都叫做预定于服务器变量。
REQUEST_URI的作用是取得当前URI,也就除域名外后面的完整的地址路径。
例子:
当前页为:http://www.test.com/home.php?id=23&cid=22
echo $_SERVER["REQUEST_URI"]
结果为:/home.php?id=23&cid=22 
4、parse_url()解析URL函数
 parse_url() 是讲URL解析成有固定键值的数组的函数 
例子

$ua=parse_url("http://username:password@hostname/path?arg=value#anchor");print_r($ua);

结果:

Array( [scheme] => http  ;协议 [host] => hostname  ;主机域名 [user] => username  ;用户 [pass] => password  ;密码 [path] => /path   ;路径 [query] => arg=value  ;取参数 [fragment] => anchor  ;)
 

5、代码实例
 这个一个留言的分页,分为3个部分,一个是数据库设计,一个是连接页面,一个是显示页面。
(1)设计数据库
 设计数据库名为bbs,有一个数据表为message,里面包含title,lastdate,user,content等字段,分别表示留言标题,留言日前,留言人,留言的内容
(2)连接页面

", str_replace(" ", " ", $content)); //两个str_replace嵌套 return $content;}//$content=str_replace("'","‘",$content); //htmlspecialchars(); ?>

(3)显示页面

123下一页阅读全文

您可能感兴趣的文章:

  • php实现的后台表格分页功能示例
  • 利用PHP访问数据库_实现分页功能与多条件查询功能的示例
  • PHP+Ajax实现的无刷新分页功能详解【附demo源码下载】
  • php基于SQLite实现的分页功能示例
  • PHP简单实现数字分页功能示例
  • php实现分页功能的详细实例方法
  • php
  • 分页

相关文章

  • php成功操作redis cluster集群的实例教程

    这篇文章主要给大家介绍了关于php成功操作redis cluster集群的实例教程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧 2019-01-01
  • PHP登录环节防止sql注入的方法浅析

    这篇文章主要介绍了PHP登录环节防止sql注入的方法,需要的朋友可以参考下 2014-06-06
  • php中如何同时使用session和cookie来保存用户登录信息

    本篇文章是对在php中同时使用session和cookie来保存用户登录信息的实现代码进行了详细的分析介绍,需要的朋友参考下 2013-07-07
  • PHP中应该避免使用同名变量(拆分临时变量)

    这篇文章主要介绍了PHP中应该避免使用同名变量(拆分临时变量),当一个临时变量被赋值多次时,那么将其拆分成多个,除非它是一个循环计数器,需要的朋友可以参考下 2015-04-04
  • PHP中冒号、endif、endwhile、endfor使用介绍

    下面的一些用法,对于相当一部分PHP爱好者来说根本没见过啊,这些是什么东西呢? 2010-04-04
  • 解析thinkphp的左右值无限分类

    本篇文章是对thinkphp的左右值无限分类进行了详细的分析介绍,需要的朋友参考下 2013-06-06
  • 个人站长制做网页常用的php代码

    个人站长制做网页常用的php代码... 2007-03-03
  • 你应该知道PHP浮点数知识

    这篇文章主要介绍了你应该知道PHP浮点数知识,本文讲解了PHP浮点数、PHP数字的临界值,精度损失等问题,需要的朋友可以参考下 2015-05-05
  • PHP实现补齐关闭的HTML标签

    这篇文章主要介绍了PHP实现补齐关闭的HTML标签的方法,通过自定义函数实现针对HTML标签的闭合补全功能,涉及PHP字符串及正则匹配相关操作技巧,需要的朋友可以参考下 2016-03-03
  • php截取视频指定帧为图片

    这篇文章主要为大家详细介绍了php截取视频指定帧为图片的相关资料,需要的朋友可以参考下 2016-05-05

最新评论


  • 上一条:
    php对二维数组进行相关操作(排序、转换、去空白等)
    下一条:
    两种php去除二维数组的重复项方法
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 用Time Warden监控PHP中的代码处理时间(0个评论)
    • 在PHP中使用array_pop + yield实现读取超大型目录功能示例(0个评论)
    • Property Hooks RFC在PHP 8.4中越来越接近现实(0个评论)
    • 近期文章
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • Laravel 11.15版本发布 - Eloquent Builder中添加的泛型(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-11
    • 2017-12
    • 2018-01
    • 2018-02
    • 2018-03
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-09
    • 2021-02
    • 2021-03
    • 2021-04
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    • 2024-05
    • 2024-06
    • 2024-07
    • 2024-09
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客