PHP常用之封装分页工具类
分页基本上是每个项目都会使用到的,所以呢,把它封装成一个工具类,以后直接调用就可以了(虽然TP框架的灰常强大,但是自己封一个也未尝不可。),这样既省时又省力还赚‘工分’。
我封的这个分页工具类还比较完整,有首页,上一页,下一页,末页和可选数量的页码数量(也就是当页面很多时,只显示依据参数传入的个数),还可以依据需求选择是否使用下拉跳转页面功能。
<?php
/**
* 分页工具类
*/ class page{ /**
* 返回分页所需字符串
* @param $pageNum int 显示的页码
* @param $pageCount int 总的页码数
* @param $url string 当前页码路径
* @param $Count string 页码列表里显示的个数
* @param $selected bool 是否开启下拉框选择功能。默认不开启
* return $strpage string 分页字符串
*/
function showPage($pageNum,$pageCount,$url,$Count = 5,$selected = false){
$pageMaxVal = $Count - 1;// 页码到达最大时,页码列表里第一个页码与最大页码的差
$pageMiddleVal = ceil($Count / 2);// 依据需要显示页码个数得到的中间值
$pageMiddleCha = floor($Count / 2);// 依据需要显示页码个数得到的当前页码与第一个页码的差 // 判断url是否已经存在?
if(!strpos($url, '?')){ // 未存在?
$url .= '?';
}else{
$url .= '&';
} // 首页
$strpage = "<a href='{$url}num=1'>首页</a>"; // 上一页
$preNum = $pageNum > 1 ? $pageNum - 1 : 1; // 当页码为第一页时取消上一页按钮的功能
$strpage .= $pageNum == 1 ? "<a class='unshow'>上一页</a>" : "<a href='{$url}num={$preNum}'>上一页</a>"; // 显示的页码列表中的第一个页码
$startPage = $pageNum > $pageMiddleVal ? $pageNum - $pageMiddleCha : 1;
// 起始页码最大值 = 总页数 - 4
if($pageCount - $pageMaxVal > 0 && $startPage > $pageCount - $pageMaxVal){
$startPage = $pageCount - $pageMaxVal;
} // 显示的页码列表中的最后一个页码
$endPage = $startPage<($pageCount - $pageMaxVal) ? $startPage + $pageMaxVal : $pageCount; // 中间数字页码
for($i=$startPage;$i<=$endPage;$i++){
if($i == $pageNum){
$strpage .= "<span>$i</span>";
}else{
$strpage .= "<a href='{$url}num=$i'>$i</a>";
}
} // 下一页
$nextNum = $pageNum < $pageCount ? $pageNum + 1 : $pageCount; // 当页码为最后一页时取消下一页按钮的功能
$strpage .= $pageNum == $pageCount ? "<a class='unshow'>下一页</a>" : "<a href='{$url}num={$nextNum}'>下一页</a>"; // 末页
$strpage .= "<a href='{$url}num={$pageCount}'>末页</a>"; // 总页数
$strpage .= "总页数:{$pageCount}  "; // 判断是否是否选择页码功能
if($selected){ // 选择了
$strpage .= "当前页码:<select onchange=\"location.href='{$url}num=' + this.value \">";
for($i = 1; $i <= $pageCount;$i++){
if($i == $pageNum){
$strpage .= "<option value='$i' selected='selected'>$i</option>";
}else{
$strpage .= "<option value='$i'>$i</option>";
}
} $strpage .= "</select>";
} return $strpage;
} }
(接下来应该会PO完MySQL剩余部分知识吧,毕竟前面PO了一点,但是不排除会抽风PO点别的,哇哒哒)
PHP常用之封装分页工具类的更多相关文章
- 分页 工具类 前后台代码 Java JavaScript (ajax) 实现 讲解
[博客园cnblogs笔者m-yb原创, 转载请加本文博客链接,笔者github: https://github.com/mayangbo666,公众号aandb7,QQ群927113708]http ...
- Workbook导出excel封装的工具类
在实际中导出excel非常常见,于是自己封装了一个导出数据到excel的工具类,先附上代码,最后会写出实例和解释.支持03和07两个版本的 excel. HSSF导出的是xls的excel,XSSF导 ...
- .NET3.5中JSON用法以及封装JsonUtils工具类
.NET3.5中JSON用法以及封装JsonUtils工具类 我们讲到JSON的简单使用,现在我们来研究如何进行封装微软提供的JSON基类,达到更加方便.简单.强大且重用性高的效果. 首先创建一个类 ...
- MySQL数据库学习笔记(十一)----DAO设计模式实现数据库的增删改查(进一步封装JDBC工具类)
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- MySQL数据库学习笔记(十)----JDBC事务处理、封装JDBC工具类
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- JAVA中封装JSONUtils工具类及使用
在JAVA中用json-lib-2.3-jdk15.jar包中提供了JSONObject和JSONArray基类,用于JSON的序列化和反序列化的操作.但是我们更习惯将其进一步封装,达到更好的重用. ...
- MySQL JDBC事务处理、封装JDBC工具类
MySQL数据库学习笔记(十)----JDBC事务处理.封装JDBC工具类 一.JDBC事务处理: 我们已经知道,事务的概念即:所有的操作要么同时成功,要么同时失败.在MySQL中提供了Commit. ...
- DAO设计模式实现数据库的增删改查(进一步封装JDBC工具类)
DAO设计模式实现数据库的增删改查(进一步封装JDBC工具类) 一.DAO模式简介 DAO即Data Access Object,数据访问接口.数据访问:故名思义就是与数据库打交道.夹在业务逻辑与数据 ...
- PageUtil.java分页工具类
package com.chabansheng.util; /** * 分页工具类 * @author Administrator * */ public class PageUtil { /** * ...
随机推荐
- 设计与实现的简单和经常使用的权限系统(五岁以下儿童):不维护节点的深度level,手工计算level,树形结构
以这种方式.和第三的类似介绍.所不同的是.深度未在数据库中存储节点level,添加和更改时间,护.而是,在程序中,实时去计算的. 至于后面的,依照level升序排序,再迭代全部的节点构造树,与第三篇 ...
- Swift初探一
今天安装了一下Xcode6-Beta版,想来体验一下Swift的魅力:安装Swift系统最低版本号为:10.9.3 仅仅看看一点The Swift Programming Language,以下给大家 ...
- html5 Geolocation(地理位置定位)学习
1.html5 Geolocation html5 Geolocation API 使用很简单,请求一个位置信息,如果用户同意,浏览器会返回一个位置信息,该位置是通过用户的底层设备(手机,电脑) 提供 ...
- Roslyn and NRefactory
1.Roslyn: 微软今天(2012-06-06)向CTP社区发布了Roslyn编译器的最新版本,它主要用于Visual Basic和C#代码,可工作于Visual Studio 2010 SP1和 ...
- [转]在 Mac OS X上编译 libimobiledevice 的方法
link: http://blog.boceto.fr/2012/05/05/libimobiledevice-for-macosx/ The objective of the day: Compil ...
- T-SQL 随机返回特定行数据和分页查询
T-SQL 随机返回特定行数据和分页查询 T-SQL 语言相较于标准SQL添加了很多特性,为了提高SQL Server的表现,是有必要深入了解的,面试时一般也会包含这两个小问题. 首先,是在一个Adv ...
- Sublime2 Text编辑器使用技巧
Sublime2 Text编辑器使用技巧 ------------------------------------软件使用----------------------------------- ...
- c语言:快速排序
练手代码(分治实现): input: int input[] = {12,6,3,9,10,6,2}; output: ======================= len = 7 input[0] ...
- 项目Splash页面的开发与设计
项目Splash页面的开发与设计 首先建立一个安卓的项目,然后修改manifest.xml文件,修改应用程序的logo和显示名称,效果图如下: 对应的代码如下: 1 <?xml version= ...
- tomcat创建一个windows服务
具体步骤如下: 1.把JDK解压到C:\Program Files\Java下,Tomcat解压到D:\tomcat下 2.配置环境变量 JAVA_HOME:C:\Program Files\Java ...