根据以往的经验,对于很多初学者,分页功能实现起来还是有一定的困难的,为了帮大家解决这样的问题:特此献上五环之歌。从此分页功能便是如小岳岳唱歌一样简练,漂亮,精干。哈哈,不闲扯了。正式进入千锋PHP五环之歌之步骤实现分页功能。
第一环:计算总的记录数—即总共要显示多少条数据
第二环: 每页显示的条数—即一般都是我们程序媛来规定每页显示几条数据。
第三环: 计算总页数—即根据以上两个条件便可求出总的页数,为了防止出现小数,我们都是向上取整。详情见下面代码:
第四环: 显示当前页面数—即我们一般在地址栏中需要传递一个分页参数,例如p=5,则5就是当前的页码数。
第五环: 计算偏移量—即这是最关键的一步,以上的步骤就是为求偏移量做铺垫的。偏移量=(当前页码数-1)* 每页显示的条数

以下是小妹做出的一个实例:
以上链接数据库部分省略:
//查询数据得到总共有多少条数据

$sql = “SELECT count() FROM test”;
$result = mysqli_query($con, $sql);
$count = mysqli_fetch_assoc($result);
$count = intval($count[‘count()’]);

//规定每页显示几条数据

$perPage = 5;

//计算总页数,并且向上取整

$pages = ceil($count/$perPage);

//显示当前页码数

$curPage = isset($_GET[‘p’]) ? min(max((int)$_GET[‘p’],1),$pages) : 1;

//最后求偏移量

$offset = ($curPage - 1) * $perPage;

//最后通过查询数据使用LIMIT来显示每页显示多条数据即可。

$sql = “SELECT * FROM test ORDER BY id DESC LIMIT $offset,
$perPage”;
$result = mysqli_query($con, $sql);

写代码就要像千锋PHP口号一样:傻X一样的坚持,才能有牛X的结果。

最新文章

  1. window.onload用法详解:
  2. 一个很酷的加载loading效果--IT蓝豹
  3. mouseleave 与 mouseout 的不同
  4. JSBinding + SharpKit / 常见问题
  5. 简单的Ajax例子
  6. Android学习-各种对话框
  7. 【LeetCode】 sort list 单清单归并
  8. Memory and Scores
  9. 2.bootstrap-全局css
  10. 【转】Linux Oracle服务启动&停止脚本与开机自启动
  11. java定时器schedule和scheduleAtFixedRate区别
  12. VS添加WebService工具
  13. .NET里面 abstract class和Interface有什么区别以及用法的展现?
  14. laravel5.5 调用系统自带登陆认证auth
  15. Markdown使用方法
  16. asp.net Request、Request.Form、Request.QueryString的区别(转)
  17. html自定义弹框
  18. 8个设计师必看的免费UI图标设计资源站
  19. Java多态性的理解2
  20. CMD下利用subst命令将一个文件夹镜像成本地的一个虚拟磁盘

热门文章

  1. 2015苏州大学ACM-ICPC集训队选拔赛(1) 1007
  2. java中double的四舍五入 BigDecimal
  3. NETCORE 之 openSUSE docker 安装
  4. 6-----BBS论坛
  5. 01 性能优化基础怀实践 之 ASH分析
  6. gitee 搭建自己的代码仓库
  7. 获取项目路径js
  8. C. Permute Digits dfs大模拟
  9. python 自动安装工具 setuptools(easy_install) 的使用
  10. C++计算二叉树的节点数和高度