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 相关文章推荐
Smarty模板快速入门
Jan 04 PHP
简单PHP上传图片、删除图片实现代码
May 12 PHP
PHP 防恶意刷新实现代码
May 16 PHP
ThinkPHP3.1新特性之Action参数绑定
Jun 19 PHP
PHP通过内置函数memory_get_usage()获取内存使用情况
Nov 20 PHP
Zend Framework路由器用法实例详解
Dec 11 PHP
PHP XML Expat解析器知识点总结
Feb 15 PHP
使用PHP反射机制来构造&quot;CREATE TABLE&quot;的sql语句
Mar 21 PHP
详解提高使用Java反射的效率方法
Apr 29 PHP
php设计模式之中介者模式分析【星际争霸游戏案例】
Mar 23 PHP
分享几种好用的PHP自定义加密函数(可逆/不可逆)
Sep 15 PHP
PHP中的输出echo、print、printf、sprintf、print_r和var_dump的示例代码
Dec 01 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
中国站长站 For Dede4.0 采集规则
2007/05/27 PHP
探讨PHP函数ip2long转换IP时数值太大产生负数的解决方法
2013/06/06 PHP
php中通过数组进行高效随机抽取指定条记录的算法
2013/09/09 PHP
php的ZipArchive类用法实例
2014/10/20 PHP
Laravel5.1 框架Request请求操作常见用法实例分析
2020/01/04 PHP
jQuery参数列表集合
2011/04/06 Javascript
jQuery CSS()方法改变现有的CSS样式
2014/08/20 Javascript
javascript与Python快速排序实例对比
2015/08/10 Javascript
基于javascript数组实现图片轮播
2016/05/02 Javascript
Three.js学习之Lamber材质和Phong材质
2016/08/04 Javascript
AngularJS入门教程之Cookies读写操作示例
2016/11/02 Javascript
ES6使用let命令更简单的实现块级作用域实例分析
2017/03/31 Javascript
详解Vue组件之间的数据通信实例
2017/06/17 Javascript
React-Native左右联动List的示例代码
2017/09/21 Javascript
详解VUE2.X过滤器的使用方法
2018/01/11 Javascript
微信小程序 函数防抖 解决重复点击消耗性能问题实现代码
2019/09/12 Javascript
vue-video-player视频播放器使用配置详解
2020/10/23 Javascript
动态实现element ui的el-table某列数据不同样式的示例
2021/01/22 Javascript
[01:20:47]DOTA2-DPC中国联赛 正赛 Ehome vs Magma BO3 第一场 1月19日
2021/03/11 DOTA
Python使用OpenCV进行标定
2018/05/08 Python
浅谈Python traceback的优雅处理
2018/08/31 Python
Python更新所有已安装包的操作
2020/02/13 Python
Python基于smtplib模块发送邮件代码实例
2020/05/29 Python
详解Python设计模式之策略模式
2020/06/15 Python
Python基于traceback模块获取异常信息
2020/07/23 Python
CSS3实现自定义Checkbox特效实例代码
2017/04/24 HTML / CSS
社会实践自我鉴定
2013/11/07 职场文书
架构师岗位职责
2013/11/18 职场文书
副董事长岗位职责
2014/04/02 职场文书
2014年酒店服务员工作总结
2014/12/08 职场文书
幼儿园教师师德师风承诺书
2015/04/28 职场文书
春节随笔
2015/08/15 职场文书
浅谈Python数学建模之线性规划
2021/06/23 Python
vue elementUI批量上传文件
2022/04/26 Vue.js
pandas中pd.groupby()的用法详解
2022/06/16 Python
postgresql之greenplum字符串去重拼接方式
2023/05/08 PostgreSQL