php+Mysql分页 类和引用详解
一下内容为专用于分页的类以及具体的方法和解析。
<?php
class Page {
private $total; //数据表中总记录数
private $listRows; //每页显示行数
private $limit; //SQL语句使用limit从句,限制获取记录个数 limit m.n
private $uri; //自动获取url的请求地址
private $pageNum; //总页数
private $page; //当前页
private $config = array( //config配置
'head' => "条记录",
'prev' => "上一页",
'next' => "下一页",
'first'=> "首页",
'last' => "末页"
);
//在分页信息中显示内容,可以自己通过set()方法设置
private $listNum = 10; //默认分页列表显示的个数
// 共10页 1/10 上一页1 2 3 4 5 下一页 /**
构造方法,可以设置分页类的属性
@param int $total 计算分页的总记录数
@param int $listRows 可选的,设置每页需要显示的记录数,默认为25条
@param mixed $query 可选的,为向目标页面传递参数,可以是数组,也可以是查询字符串格式
@param bool $ord 可选的,默认值为true, 页面从第一页开始显示,false则为最后一页
*/
public function __construct($total, $listRows=25, $query="", $ord=true){
$this->total = $total;
$this->listRows = $listRows;
$this->uri = $this->getUri($query);
//获取浏览器地址栏中的地址
$this->pageNum = ceil($this->total / $this->listRows);
//总共多少页
/*以下判断用来设置当前面*/
if(!empty($_GET["page"])) {
$page = $_GET["page"];
}else{
if($ord)
$page = 1;
else
$page = $this->pageNum;
} if($total > 0) {
if(preg_match('/\D/', $page) ){
$this->page = 1;
}else{
$this->page = $page;
}
}else{
$this->page = 0;
} $this->limit = "LIMIT ".$this->setLimit();
} 用于设置显示分页的信息,可以进行连贯操作
@param string $param 是成员属性数组config的下标
@param string $value 用于设置config下标对应的元素值
@return object 返回本对象自己$this, 用于连惯操作
*/
function set($param, $value){
if(array_key_exists($param, $this->config)){
$this->config[$param] = $value;
}
return $this;
} /* 不是直接去调用,通过该方法,可以使用在对象外部直接获取私有成员属性limit和page的值 */
function __get($args){
if($args == "limit" || $args == "page")
return $this->$args;
else
return null;
} /**
按指定的格式输出分页
@param int 0-7的数字分别作为参数,用于自定义输出分页结构和调整结构的顺序,默认输出全部结构
@return string 分页信息内容
*/ // 共10页 1/10 上一页1 2 3 4 5 下一页 function fpage(){
$arr = func_get_args(); $html[0] = "<span class='p1'> 共<b> {$this->total} </b>{$this->config["head"]} </span>";
//共100条记录
$html[1] = " 本页 <b>".$this->disnum()."</b> 条 ";
//本页10条(因最后一页不确定)
$html[2] = " 本页从 <b>{$this->start()}-{$this->end()}</b> 条 ";
//本页从11-20条
$html[3] = " <b>{$this->page}/{$this->pageNum}</b>页 ";
// 2/10页 $html[4] = $this->firstprev();
//首页 上一页
$html[5] = $this->pageList();
//1 2 3 4 5
$html[6] = $this->nextlast();
//下一页 尾页
$html[7] = $this->goPage();
// [] go (跳转)
$fpage = '<div style="font:12px \'\5B8B\4F53\',san-serif;">';
if(count($arr) < 1)
$arr = array(0, 1,2,3,4,5,6,7); for($i = 0; $i < count($arr); $i++)
$fpage .= $html[$arr[$i]]; $fpage .= '</div>';
return $fpage;
} /* 在对象内部使用的私有方法,*/
private function setLimit(){
if($this->page > 0)
return ($this->page-1)*$this->listRows.", {$this->listRows}";
else
return 0;
} /* 在对象内部使用的私有方法,用于自动获取访问的当前URL */
private function getUri($query){
$request_uri = $_SERVER["REQUEST_URI"];
$url = strstr($request_uri,'?') ? $request_uri : $request_uri.'?'; if(is_array($query))
$url .= http_build_query($query);
else if($query != "")
$url .= "&".trim($query, "?&"); $arr = parse_url($url); if(isset($arr["query"])){
parse_str($arr["query"], $arrs);
unset($arrs["page"]);
$url = $arr["path"].'?'.http_build_query($arrs);
} if(strstr($url, '?')) {
if(substr($url, -1)!='?')
$url = $url.'&';
}else{
$url = $url.'?';
} return $url;
} /* 在对象内部使用的私有方法,用于获取当前页开始的记录数 */
private function start(){
if($this->total == 0)
return 0;
else
return ($this->page-1) * $this->listRows+1;
} /* 在对象内部使用的私有方法,用于获取当前页结束的记录数 */
private function end(){
return min($this->page * $this->listRows, $this->total);
}
//min 取两个里小的 在对象内部使用的私有方法,用于获取上一页和首页的操作信息
private function firstprev(){
if($this->page > 1) {
$str = " <a href='{$this->uri}page=1'>{$this->config["first"]}</a> ";
$str .= "<a href='{$this->uri},page=".($this->page-1)."'>{$this->config["prev"]}</a> ";
return $str;
} } 在对象内部使用的私有方法,用于获取页数列表信息
private function pageList(){
$linkPage = " <b>"; $inum = floor($this->listNum/2);//floor向下取整
/*当前页前面的列表 */
for($i = $inum; $i >= 1; $i--){
$page = $this->page-$i; if($page >= 1)
$linkPage .= "<a href='{$this->uri}page={$page}'>{$page}</a> ";
}
/*当前页的信息 */
if($this->pageNum > 1)
$linkPage .= "<span style='padding:1px 2px;background:#BBB;color:white'>{$this->page}</span> "; /*当前页后面的列表 */
for($i=1; $i <= $inum; $i++){
$page = $this->page+$i;
if($page <= $this->pageNum)
$linkPage .= "<a href='{$this->uri}page={$page}'>{$page}</a> ";
else
break;
}
$linkPage .= '</b>';
return $linkPage;
} 在对象内部使用的私有方法,获取下一页和尾页的操作信息
private function nextlast(){
if($this->page != $this->pageNum) {
$str = " <a href='{$this->uri}page=".($this->page+1)."'>{$this->config["next"]}</a> ";
$str .= " <a href='{$this->uri}page=".($this->pageNum)."'>{$this->config["last"]}</a> ";
return $str;
}
} 在对象内部使用的私有方法,用于显示和处理表单跳转页面
private function goPage(){
if($this->pageNum > 1) {
return ' <input style="width:20px;height:17px !important;height:18px;border:1px solid #CCCCCC;" type="text" onkeydown="javascript:if(event.keyCode==13){var page=(this.value>'.$this->pageNum.')?'.$this->pageNum.':this.value;location=\''.$this->uri.'page=\'+page+\'\'}" value="'.$this->page.'"><input style="cursor:pointer;width:25px;height:18px;border:1px solid #CCCCCC;" type="button" value="GO" onclick="javascript:var page=(this.previousSibling.value>'.$this->pageNum.')?'.$this->pageNum.':this.previousSibling.value;location=\''.$this->uri.'page=\'+page+\'\'"> ';
}
} 在对象内部使用的私有方法,用于获取本页显示的记录条数
private function disnum(){
if($this->total > 0){
return $this->end()-$this->start()+1;
}else{
return 0;
}
}
}
引用操作如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<?php
//引入类(分页类10-24博客)
require_once "YIN.class.php";
require_once "../t/page.class.php";
$db = new YIN();
//取数据总条数
$zts = "select count(*) from wg";
$sql = $db->StrQuery($zts);
//造对象
$page = new Page($sql,15);
//在obj后边加上分页,拼接
$obj = "select * from wg ".$page->limit;
$data = $db->Query($obj);
?>
<table>
<tr>
<td>员工编号</td><td>工资</td><td>时间</td>
</tr>
<?php
foreach ($data as $i){
echo "<tr>
<td>{$i[0]}</td><td>{$i[1]}</td><td>{$i[2]}</td>
</tr>";
}
?>
</table>
<div>
<?php
输出显示列表分页,上面类里面有具体哪个模块的功能和解析,这里选择的是3,4,5,6模块的功能,小伙伴们可以根据自己的需求用,不写的话就是全部使用
echo $page->fpage(3,4,5,6);
?>
</div>
</body>
</html> 《--结束--》 孔雀东南飞,五里一徘徊。十三能织素,十四学裁衣。十五弹箜篌,十六诵诗书。十七为君妇,心中常苦悲。君既为府吏,守节情不移。贱妾留空房,相见常日稀。 鸡鸣入机织,夜夜不得息。三日断五疋,大人故嫌迟。非为织作迟,君家妇难为。妾不堪驱使,徒留无所施。便可白公姥,及时相遣归。府吏得闻之,堂上启阿母。 儿已薄禄相,幸复得此妇。结发同枕席,黄泉共为友。共事二三年,始而未为久。女行无偏斜,何意致不厚。阿母谓府吏,何乃太区区。此妇无礼节,举动自专由。
吾意久怀忿,汝岂得自由。东家有贤女,自名秦罗敷。可怜体无比,阿母为汝求。便可速遣之,遣去慎莫留。府吏长跪告,伏惟启阿母。今若遣此妇,终老不复娶。 阿母得闻之,槌床便大怒。小子无所畏,何敢助妇语。吾已失恩意,会不相从许。府吏默无声,再拜还入户。举言谓新妇,哽咽不能语。我自不驱卿,逼迫有阿母。 卿但暂还家,吾今且报府。不久当归还,还必相迎取。以此下心意,慎勿违我语。新妇谓府吏,勿复重纷纭。往昔初阳岁,谢家来贵门。奉事循公姥,进止敢自专。 昼夜勤作息,伶俜萦苦辛。谓言无罪过,供养卒大恩。仍更被驱遣,何言复来还。妾有绣腰襦,葳蕤自生光。红罗复斗帐,四角垂香囊。箱帘六七十,绿碧青丝绳。 物物各具异,种种在其中。人贱物亦鄙,不足迎后人。留待作遣施,于今无会因。时时为安慰,久久莫相忘。鸡鸣外欲曙,新妇起严妆。著我绣夹裙,事事四五通。 足下蹑丝履,头上玳瑁光。腰若流纨素,耳著明月当。指如削葱根,口如含珠丹。纤纤作细步,精妙世无双。上堂谢阿母,母听怒不止。昔作女儿时,生小出野里。 本自无教训,兼愧贵家子。受母钱币多,不堪母驱使。今日还家去,念母劳家里。却与小姑别,泪落连珠子。新妇初来时,小姑始扶床。今日被驱遣,小姑如我长。 勤心养公姥,好自相扶将。初七及下九,嬉戏莫相忘。出门登车去,涕落百余行。府吏马在前,新妇车在后。隐隐何甸甸,俱会大通口。下马入车中,低头共耳语。 誓不相隔卿,且暂还家去。吾今且赴府,不久当还归。誓天不相负,新妇谓府吏。感君区区怀,君既若见录。不久望君来,君当作磐石。
php+Mysql分页 类和引用详解的更多相关文章
- MySQL Cluster 配置文件(config.ini)详解
MySQL Cluster 配置文件(config.ini)详解 ################################################################### ...
- MySQL数据类型以及基本使用详解
MySQL数据类型以及基本使用详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.MySQL服务器的主要组件 我们知道MySQL的主要组件主要是由服务端(mysqld)和客户端 ...
- 深入MySQL用户自定义变量:使用详解及其使用场景案例
一.前言 在前段工作中,曾几次收到超级话题积分漏记的用户反馈.通过源码的阅读分析后,发现问题出在高并发分布式场景下的计数器上.计数器的值会影响用户当前行为所获得积分的大小.比如,当用户在某超级话题下连 ...
- 【转】UML类图与类的关系详解
UML类图与类的关系详解 2011-04-21 来源:网络 在画类图的时候,理清类和类之间的关系是重点.类的关系有泛化(Generalization).实现(Realization).依赖(D ...
- [转]c++类的构造函数详解
c++构造函数的知识在各种c++教材上已有介绍,不过初学者往往不太注意观察和总结其中各种构造函数的特点和用法,故在此我根据自己的c++编程经验总结了一下c++中各种构造函数的特点,并附上例子,希望对初 ...
- UML类图与类的关系详解
摘自:http://www.uml.org.cn/oobject/201104212.asp UML类图与类的关系详解 2011-04-21 来源:网络 在画类图的时候,理清类和类之间的关系是重点.类 ...
- C++引用(&)详解
C++引用详解 引用的概念 引用:就是某一变量(目标)的一个别名,对引用的操作与对变量直接操作完全一样. 引用的声明方法:类型标识符 &引用名=目标变量名: 如下:定义引用ra,它是变量a的引 ...
- mysql中SQL执行过程详解与用于预处理语句的SQL语法
mysql中SQL执行过程详解 客户端发送一条查询给服务器: 服务器先检查查询缓存,如果命中了缓存,则立刻返回存储在缓存中的结果.否则进入下一阶段. 服务器段进行SQL解析.预处理,在优化器生成对应的 ...
- c++类的构造函数详解
c++类的构造函数详解 一. 构造函数是干什么的 class Counter{ public: // 类Counter的构造函数 // 特点:以类名作为函数名,无返回类 ...
随机推荐
- 整理关于 VS Code 一些小技巧:系列一
官方介绍 VisualStudioCode是一个轻量级且功能强大的源代码编辑器,它运行在桌面上,支持Windows.MacOS和Linux系统.它提供了对JavaScript.TypeScript和N ...
- Vue nodejs商城项目-商品列表页面组件
data(){ return { goodsList:[], // 商品列表 priceFilter:[ // 价格区间数组 ...
- Python 学习笔记(四)数字(二)
Python Python2 中除法的问题 >>> 3 / 6 0 >>> 3.0 / 6 0.5 >>> 3.0 / 6.0 0.5 >& ...
- js日期相减得到分钟数
const date1 = new Date(fieldsValue.examStartTime); const date2 = new Date(fieldsValue.examEndTime); ...
- #leetcode刷题之路5-最长回文子串
给定一个字符串 s,找到 s 中最长的回文子串.你可以假设 s 的最大长度为 1000. 示例 1:输入: "babad"输出: "bab"注意: " ...
- Linux进程间通信---管道和有名管道
一.管道 管道:管道是一种半双工的通信方式,数据只能单方向流动,而且只能在具有亲缘关系的进程间使用,因为管道 传递数据的单向性,管道又称为半双工管道.进程的亲缘关系通常是指父子进程关系. 管道的特点决 ...
- A^B Mod C (51Nod - 1046 )(快速幂)
给出3个正整数A B C,求A^B Mod C. 例如,3 5 8,3^5 Mod 8 = 3. Input 3个正整数A B C,中间用空格分隔.(1 <= A,B,C <= 10^ ...
- Apache Maven(六):存储库
Maven 存储库主要是存放一些第三方依赖jar包等. 严格来说,只有两种存储库:本地和远程,本地存储库是指您远程下载到本地的一个缓存,还包含尚未发布的临时构建文件.远程存储库是指一些可以通过各种协议 ...
- ThinkPHP框架目录的介绍
library目录 Think目录 mvc
- Laravel POST请求API接口 使用validate表单验证返回欢迎页
突然遇到的问题 就是使用Laravel进行开发API接口的时候 发现在表单验证不通过的时候返回了登录页 猜测问题应该是因为表单验证失败后进行了重定向导致的 因为返回状态码200 网上找了好久没找到 ...