百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

OOP理解应用之分页类 分页技术

yuyutoo 2024-10-31 16:41 4 浏览 0 评论

一、开发背景

前面实现的分页可能每次都需要重新设计和编写,不符合面向对象的特征,按照面向对象的设计理念来封装分页类可以极大的提供工作效率。

二、实现效果

三、主要源码

<?php

/*

Describe:分页类完成不同的数据库不同的数据表分页功能,支持联表

*/

include_once('config.inc.php');

class Pager{

private $pageIndex;//当前页数

private $pageSize;//每页显示的记录数

private $count;//总记录数

private $pageCount;//总页数

private $condition;//查询条件

private $order;//排序

private $mysql;//数据操作类对象

private $tableName;//需要分页的表

//当前页数属性

function setPageIndex($value){

$this->pageIndex=$value;

}

function getPageIndex(){

return $this->pageIndex;

}

//每页显示记录数

function setPageSize($value){

$this->pageSize=$value;

//改变每页显示的记录数会影响总页数

$this->getPageCount();

}

function getPageSize(){

return $this->pageSize;

}

//总记录数

function getCount(){

$this->InnerGetCount();//调用自己的内部函数

return $this->count;

}

//总页数

function getPageCount(){

$this->InnerGetCount();

$this->pageCount=ceil($this->count/$this->pageSize);

if($this->pageCount==0)//没有符合的记录条数默认为1页

$this->pageCount=1;

return $this->pageCount;

}

//查询条件

function setCondition($value){

$this->condition=$value;

//设置条件会影响总记录数和总页数

$this->getPageCount();

}

//排序

function setOrder($value){

$this->order=$value;

}

//数据库操作类对象

function getMysql(){

return $this->mysql;

}

//构造函数初始化配置,$table需要分页的表

function __construct($tableName){

$this->tableName=$tableName;

$this->pageIndex=1;//默认为第1页

$this->pageSize=1;//每页显示记录数,默认为10条

$this->count=0;

$this->pageCount=1;

$this->condition='';

$this->order='';

//数据库操作类对象

if(DBTYPE=='mysqli'){

include_once('MysqliHelper.php');

$this->mysql=new MysqliHelper(DB);//无法通过魔术函数自动装载

}

elseif(DBTYPE=='mysql'){

include_once('MysqlHelper.php');

$this->mysql=new MysqlHelper(DB);//无法通过魔术函数自动装载

}

}

//获取分页记录

function GetRecord(){

$sql='select * from '.$this->tableName.' where 1=1 '.$this->condition.' '.$this->order.' limit '.($this->pageIndex-1)*$this->pageSize.','.$this->pageSize;

return $this->mysql->Execute($sql);

}

//获取总记录数

private function InnerGetCount(){

$sql="select count(*) from ".$this->tableName." where 1=1 ".$this->condition;

$result=$this->mysql->Execute($sql,2);

$this->count=$result[0][0];

}

}

?>

四、测试

<form action="index.php" method="post">

按:标题或内容包含<input name="key" id="key" value="<?php echo $key;?>" /><input type="submit" value=" 搜 索 " />

</form>

<p><a href="index.php?or=1">序号</a> 标题</p>

<?php

include_once('mysql/Pager.php');//引入

$pager=new Pager('(select ttid,ttname from tt) as temp');

//翻页

if($_GET['pi'])

$pager->setPageIndex($_GET['pi']);

$pager->setPageSize(1);

//搜索

if($_REQUEST['key']){

$key=$_REQUEST['key'];

$pager->setCondition("and (ttname like '%$key%' or ttc like '%$key%')");

}

//排序

if($_GET['or']){

$or=$_GET['or'];

$pager->setOrder("order by ttid desc");

}

$arr=$pager->GetRecord();

if(count($arr)){

foreach($arr as $row){

echo "<p>$row[ttid] $row[ttname]</p>";

}

}

if($pager->getPageIndex()==1)//首页

echo '首页&nbsp;&nbsp;上一页&nbsp;&nbsp;';

else

echo "<a href='index.php?pi=1'>首页</a>&nbsp;&nbsp;<a href='index.php?pi=".($pager->getPageIndex()-1)."'>上一页</a>&nbsp;&nbsp;";

//提示信息

echo "当前:".$pager->getPageIndex()."页/共".$pager->getPageCount()."页 每页显示<input style='width:30px;' value='".$pager->getPageSize()."'>条/共".$pager->getCount()."条记录&nbsp;&nbsp;";

if($pager->getPageIndex()==$pager->getPageCount())//尾页

echo '下一页&nbsp;&nbsp;尾页';

else

echo "<a href='index.php?pi=".($pager->getPageIndex()+1)."&key=$key'>下一页</a>&nbsp;&nbsp;<a href='index.php?pi=".$pager->getPageCount()."'>尾页</a>&nbsp;&nbsp;";

?>

五、类访问修饰符

和类成员访问修饰符一样,类有一些访问修饰符有着特殊的作用,比如static、abstract等。

<?php

class test{

private $tt;

//protected外部对象无法访问,本类和子类可以访问

public function setTT($value){

$this->tt=$value;

}

public function getTT(){

return $this->tt;

}

function tf(){

echo $this->tt;

}

}

$test=new test();

$test->setTT('aaa');

echo $test->getTT();

echo '<br>';

(new test())->setTT('bbb');//实例化时不用对象保存必须要加小括号

echo (new test())->getTT();//再次实例化默认值为空

?>

有的时候,我们系统类的成员赋值以后不系统实例化对象来进行访问,而且别的页面也可以访问这个值,可以在类成员中加上static(静态)关键字。

<?php

class test{

static function tf(){

echo 'bbb';

}

}

test::tf();

?>

注意:静态函数访问的变量必须是静态的,反之静态成员不一定保存在静态类中。

再看下面的代码

<?php

class test{

static public $tt='aaa';

function tf(){

self::$tt='bbb';//类的静态成员内部访问只能使用self::

echo self::$tt;

}

}

echo test::$tt;//类名::成员

(new test())->tf();

?>

跨页面保存数据,静态类成员访问时不能实例化直接类名::$变量

Index.php代码

<?php

class test{

static public $tt='aaa';

function tf(){

self::$tt='bbb';//类的静态成员内部访问只能使用self::

echo self::$tt;

}

}

?>

直接获取,index1.php代码

<?php

include_once('index.php');

echo test::$tt;

?>

相关推荐

【Socket】解决UDP丢包问题

一、介绍UDP是一种不可靠的、无连接的、基于数据报的传输层协议。相比于TCP就比较简单,像写信一样,直接打包丢过去,就不用管了,而不用TCP这样的反复确认。所以UDP的优势就是速度快,开销小。但是随之...

深入学习IO多路复用select/poll/epoll实现原理

Linux服务器处理网络请求有三种机制,select、poll、epoll,本文打算深入学习下其实现原理。0.结论...

25-1-Python网络编程-基础概念

1-网络编程基础概念1-1-基本概念1-2-OSI七层网络模型OSI(开放系统互联)七层网络模型是国际标准化组织(ISO)提出的网络通信分层架构,用于描述计算机网络中数据传输的过程。...

Java NIO多路复用机制

NIO多路复用机制JavaNIO(Non-blockingI/O或NewI/O)是Java提供的用于执行非阻塞I/O操作的API,它极大地增强了Java在处理网络通信和文件系统访问方面的能力。N...

Python 网络编程完全指南:从零开始掌握 Socket 和网络工具

Python网络编程完全指南:从零开始掌握Socket和网络工具在现代应用开发中,网络编程是不可或缺的技能。Python提供了一系列高效的工具和库来处理网络通信、数据传输和协议操作。本指南将从...

Rust中的UDP编程:高效网络通信的实践指南

在实时性要求高、允许少量数据丢失的场景中,UDP(用户数据报协议)凭借其无连接、低延迟的特性成为理想选择。Rust语言凭借内存安全和高性能的特点,为UDP网络编程提供了强大的工具支持。本文将深入探讨如...

Python 网络编程的基础复习:理解Socket的作用

计算机网络的组成部分在逻辑上可以划分为这样的结构五层网络体系应用层:应用层是网络协议的最高层,解决的是具体应用问题...

25-2-Python网络编程-TCP 编程示例

2-TCP编程示例应用程序通常通过“套接字”(socket)向网络发出请求或者应答网络请求,使主机间或者一台计算机上的进程间可以通信。Python语言提供了两种访问网络服务的功能。...

linux下C++ socket网络编程——即时通信系统(含源码)

一:项目内容本项目使用C++实现一个具备服务器端和客户端即时通信且具有私聊功能的聊天室。目的是学习C++网络开发的基本概念,同时也可以熟悉下Linux下的C++程序编译和简单MakeFile编写二:需...

Python快速入门教程7:循环语句

一、循环语句简介循环语句用于重复执行一段代码块,直到满足特定条件为止。Python支持两种主要的循环结构:for循环和while循环。...

10分钟学会Socket通讯,学不会你打我

Socket通讯是软硬件直接常用的一种通讯方式,分为TCP和UDP通讯。在我的职业生涯中,有且仅用过一次UDP通讯。而TCP通讯系统却经常写,正好今天写了一个TCP通讯的软件。总结一下内容软件使用C#...

Python 高级编程之网络编程 Socket(六)

一、概述Python网络编程是指使用Python语言编写的网络应用程序。这种编程涉及到网络通信、套接字编程、协议解析等多种方面的知识。...

linux网络编程Socket之RST详解

产生RST的三个条件:1.目的地为某端口的SYN到达,然而该端口上没有正在监听的服务器;2.TCP想取消一个已有的连接;3.TCP接收到一个根本不存在的连接上的分节;现在模拟上面的三种情况:cl...

ABB机器人编程实用技巧,多项案例

...

Python中实现Socket通讯(附详细代码)

套接字(socket)是一种在计算机网络中进行进程间通信的方法,它允许不同主机上的程序通过网络相互通信。套接字是网络编程的基础,几乎所有的网络应用程序都使用某种形式的套接字来实现网络功能。套接字可以用...

取消回复欢迎 发表评论: