PHP封装的分页类与简单用法示例


Posted in PHP onFebruary 25, 2019

本文实例讲述了PHP封装的分页类与简单用法。分享给大家供大家参考,具体如下:

分页类的封装如下:

page.php

<?php
//showPage(页号,总页数,分隔符)
function showPage($page,$totalPage,$sep=" "){
  $url = $_SERVER ['PHP_SELF'];      //获取当前路径
  $index = ($page == 1) ? "首页" : "<a href='{$url}?page=1'>首页</a>";
  $last = ($page == $totalPage) ? "尾页" : "<a href='{$url}?page={$totalPage}'>尾页</a>";
  $prevPage=($page>=1)?$page-1:1;
  $nextPage=($page>=$totalPage)?$totalPage:$page+1;
  $prev = ($page == 1) ? "上一页" : "<a href='{$url}?page={$prevPage}'>上一页</a>";
  $next = ($page == $totalPage) ? "下一页" : "<a href='{$url}?page={$nextPage}'>下一页</a>";
  $str = "总共{$totalPage}页/当前是第{$page}页";
  $p="";
  for($i = 1; $i <= $totalPage; $i ++) {
    //当前页无连接
    if ($page == $i) {
      $p .= "[{$i}]";
    } else {
      $p .= "<a href='{$url}?page={$i}'>[{$i}]</a>";
    }
  }
  $pageStr=$str.$sep . $index .$sep. $prev.$sep . $p.$sep . $next.$sep . $last;
  return $pageStr;  //返回分页字符串
}

一个调用分页类的例子

userlist.php

<?php
include "../mysql.php";
include "../page.php";
//连接数据库
$conn=new Mysql();
//
$pageSize=2;    //每页显示的记录数
$sql="select * from user;";
$totalRows=$conn->getResultNum($sql);  //总记录数
$totalPage=ceil($totalRows/$pageSize); //总页数
$page=isset($_REQUEST['page'])?(int)$_REQUEST['page']:1;//当前页数
if($page<1||$page==null||!is_numeric($page)){
  $page=1;
}
if($page>=$totalPage)$page=$totalPage;
$offset=($page-1)*$pageSize;
$sql="select * from user limit {$offset},{$pageSize}";
$result=$conn->sql($sql);
echo "<table style='text-align: center'>";
echo "<tr><td>用户名</td><td>密码</td><td>性别</td><td>邮箱</td></tr>";
foreach ($result as $k=>$v)
{
  echo "<tr><td>{$v['name']}</td>";
  echo "<td>"."{$v['password']}"."</td>";
  echo "<td>{$v['sex']}</td>";
  echo "<td>{$v['email']}</td></tr>";
}
echo "</table>";
echo showPage($page,$totalPage);    //输出页码链接
echo"<hr/>";
//关闭数据库
$conn->close();

运行结果:

PHP封装的分页类与简单用法示例

PHP封装的分页类与简单用法示例

数据库的封装之前写过,这里不在赘述:

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

PHP 相关文章推荐
PHP的栏目导航程序
Oct 09 PHP
PHP脚本的10个技巧(5)
Oct 09 PHP
php ss7.5的数据调用 (笔记)
Mar 08 PHP
详解php的魔术方法__get()和__set()使用介绍
Sep 19 PHP
php在程序中将网页生成word文档并提供下载的代码
Oct 09 PHP
PHP设置图片文件上传大小的具体实现方法
Oct 11 PHP
PHP四舍五入、取整、round函数使用示例
Feb 06 PHP
php中使用in_array() foreach array_search() 查找数组是否包含时的性能对比
Apr 14 PHP
php使用Jpgraph绘制3D饼状图的方法
Jun 10 PHP
php生成过去100年下拉列表的方法
Jul 20 PHP
php字符串操作针对负值的判断分析
Jul 28 PHP
php实现和c#一致的DES加密解密实例
Jul 24 PHP
PHP实现的用户注册表单验证功能简单示例
Feb 25 #PHP
PHP封装mysqli基于面向对象的mysql数据库操作类与用法示例
Feb 25 #PHP
Laravel核心解读之异常处理的实践过程
Feb 24 #PHP
PHP通过GD库实现验证码功能示例
Feb 23 #PHP
php中file_get_contents()函数用法实例
Feb 21 #PHP
PHP基于mcript扩展实现对称加密功能示例
Feb 21 #PHP
PHP+jQuery实现双击修改table表格功能示例
Feb 21 #PHP
You might like
终于听上了直流胆调频
2021/03/02 无线电
PHP set_time_limit(0)长连接的实现分析
2010/03/02 PHP
PHP中使用localhost连接Mysql不成功的解决方法
2014/08/20 PHP
PHP中STDCLASS用法实例分析
2016/11/11 PHP
laravel5表单唯一验证的实例代码
2019/09/30 PHP
JavaScript中实现块作用域的方法
2010/04/01 Javascript
左侧是表头的JS表格控件(自写,网上没有的)
2013/06/04 Javascript
解析Jquery取得iframe中元素的几种方法
2013/07/04 Javascript
JS.findElementById()使用介绍
2013/09/21 Javascript
js去除空格的12种实用方法
2013/11/08 Javascript
javascript 面向对象封装与继承
2014/11/27 Javascript
JavaScript创建一个object对象并操作对象属性的用法
2015/03/23 Javascript
JS获取iframe中longdesc属性的方法
2015/04/01 Javascript
jQuery固定元素插件scrolltofixed使用指南
2015/04/21 Javascript
js实现百度搜索提示框
2017/02/05 Javascript
详解使用nodeJs安装Vue-cli
2017/05/17 NodeJs
vue自动化表单实例分析
2018/05/06 Javascript
12个提高JavaScript技能的概念(小结)
2019/05/09 Javascript
layui lay-verify form表单自定义验证规则详解
2019/09/18 Javascript
vue 实现cli3.0中使用proxy进行代理转发
2019/10/30 Javascript
使用 UniApp 实现小程序的微信登录功能
2020/06/09 Javascript
react使用antd表单赋值,用于修改弹框的操作
2020/10/29 Javascript
Python实现读取目录所有文件的文件名并保存到txt文件代码
2014/11/22 Python
Python中Iterator迭代器的使用杂谈
2016/06/20 Python
Python 正则表达式入门(中级篇)
2016/12/07 Python
基于python中的TCP及UDP(详解)
2017/11/06 Python
Python基于read(size)方法读取超大文件
2020/03/12 Python
浅谈Python3多线程之间的执行顺序问题
2020/05/02 Python
Boolean b = new Boolean(“abcde”); 会编译错误码
2013/11/27 面试题
《老王》教学反思
2014/02/23 职场文书
体育之星事迹材料
2014/05/11 职场文书
红色故事演讲稿
2014/05/22 职场文书
公司副总经理岗位职责
2015/04/08 职场文书
nginx处理http请求实现过程解析
2021/03/31 Servers
Python基本知识点总结
2022/04/07 Python
SpringBoot详解执行过程
2022/07/15 Java/Android