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的构造函数 // 特点:以类名作为函数名,无返回类 ...
随机推荐
- 读取静态的json文件
<!DOCTYPE html><html><head><meta http-equiv="Content-Type" content=&q ...
- c#常用数据库封装再次升级
c#封装的几类数据库操作: 1.sqilte 2.berkeleydb 3.一般数据库 4.redis 包含其他项目: 1.序列化 2.通信 3.自定义数据库连接池 再次升级内容: 1.新增redis ...
- SmallMQ发布
最近一直学习,主要处理java的分布式,MQ,RPC,通信,数据库,缓存等方向. 一般现在的MQ都是企业级的,庞大,功能齐全.最主要是代码量大,对于我们这些小程序员而言,太大,修改困难,修复更加困难, ...
- vue入门:实现图片点击切换
1.实现功能 2.目录结构 3.代码 <!DOCTYPE html> <html lang="en"> <head> <meta char ...
- go 下面定义嵌套结构
package main import ( "fmt" ) const ( URL = "http://www.163.com" UID = "adm ...
- js文件处理File
支持File API的浏览器有IE10+,Firefox3.5+,Opera10.6+,Safari5+,Chrome. 1.在表单元素上<input type="fiel" ...
- WordPress博客插件程序:搜索下拉框openSug
百度搜索框下拉提示Wordpress组插件. 下载地址:https://www.opensug.org/faq/wp-content/uploads/2018/12/opensug.wordpress ...
- python-三级菜单的优化实现
三级菜单需求: 1.可依次选择进入各子菜单 2.可从任意一层往回退到上一层 3.可从任意一层退出程序 所需新知识点:列表.字典 先通过字典建立数据结构 #创建字典 city_dic = { " ...
- ubuntu 14.04离线安装docker和docker compose
准备安装包 1.下载docker docker支持以下版本的ubuntu系统Artful 17.10 (Docker CE 17.11 Edge)Zesty 17.04Xenial 16.04 (LT ...
- Java学习笔记十三:Java中的类和对象
Java中的类和对象 一:什么是对象: 总的来说就是"万物皆对象",客观存在的事物皆为对象.是计算机所关注的具体信息. 对象(object)是一件事.一个物体.一个名词,或可以获得 ...