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 { /** * ...
随机推荐
- 大批量烧写openwrt系统
http://wiki.openwrt.org/toh/tp-link/tl-wr1043nd OEM mass flashing Flashing hundreds of devices using ...
- android的EditText获取另一个焦点
在android关于开发过程EditText在setFocusable(false);后,设置时需要再次获得输入焦点setFocusable(true);问题后仍然无法获得焦点: 解决的方法: 对Ed ...
- jquery中的一点工作小记
在做一个页面的时候,网页中由许多块相同的地方 ,例如页面中会有多个地方用到TAB 效果,在使用each()遍历以后 不一定会正常显示,这是因为写的html静态页面中只有当前板块中有这个的类,若是用J ...
- 关于 js 中的 call 和 apply使用理解
关于 js 中的 call 和 apply使用理解 在学习新的东西时候,碰到以前看过而又不理解,或则记忆不深的地方不妨回头看看书里知识点,有助于加深理解.正所谓--温故而知新. 废话不多说,直接上代码 ...
- Unity 3.5
ASP.NET Web Forms 的 DI 應用範例 跟 ASP.NET MVC 与 Web API 比起来,在 Web Forms 应用程式中使用 Dependency Injection 要来的 ...
- 一道sql面试题(查询语句)
一道sql面试题(查询语句) id name age 1 a 11 2 b 11 3 c 12 4 d 13 5 e ...
- css 初始化
html,body,h1,h2,h3,h4,h5,h6,div,dl,dt,dd,ul,ol,li,p,blockquote,pre,hr,figure,table,caption,th,td,for ...
- CSDN 高校俱乐部: 排列搜索
CSDN 高校俱乐部/英雄会 题目: 设数组a包含n个元素恰好是0..n - 1的一个排列,给定b[0],b[1],b[2],b[3]问有多少个0..n-1的排列a,满足(a[a[b[0]]]*b[0 ...
- NoSql数据库使用
NoSql数据库使用半年后在设计上面的一些心得 NoSql数据库这个概念听闻许久了,也陆续看到很多公司和产品都在使用,优缺点似乎都被分析的清清楚楚.但我心里一直存有一个疑惑,它的出现究竟是为了解决什么 ...
- iOS基础 - 完善键盘处理
1.完善键盘处理 步骤一:创建一个数组,里面装着所有的文本框. 步骤二:监听所有文本框的开始编辑,设置所有文本框的代理为控制器 1.设置生日和城市不允许键盘输入 2.当开始编辑的时候调用,用一个成员属 ...