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

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

yuyutoo 2024-10-31 16:41 2 浏览 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;

?>

相关推荐

MySQL5.5+配置主从同步并结合ThinkPHP5设置分布式数据库

前言:本文章是在同处局域网内的两台windows电脑,且MySQL是5.5以上版本下进行的一主多从同步配置,并且使用的是集成环境工具PHPStudy为例。最后就是ThinkPHP5的分布式的连接,读写...

thinkphp5多语言怎么切换(thinkphp5.1视频教程)

thinkphp5多语言进行切换的步骤:第一步,在配置文件中开启多语言配置。第二步,创建多语言目录。相关推荐:《ThinkPHP教程》第三步,编写语言包。视图代码:控制器代码:效果如下:以上就是thi...

基于 ThinkPHP5 + Bootstrap 的后台开发框架 FastAdmin

FastAdmin是一款基于ThinkPHP5+Bootstrap的极速后台开发框架。主要特性基于Auth验证的权限管理系统支持无限级父子级权限继承,父级的管理员可任意增删改子级管理员及权限设置支持单...

Thinkphp5.0 框架实现控制器向视图view赋值及视图view取值操作示

本文实例讲述了Thinkphp5.0框架实现控制器向视图view赋值及视图view取值操作。分享给大家供大家参考,具体如下:Thinkphp5.0控制器向视图view的赋值方式一(使用fetch()方...

thinkphp5实现简单评论回复功能(php评论回复功能源码下载)

由于之前写评论回复都是使用第三方插件:畅言所以也就没什么动手,现在证号在开发一个小的项目,所以就自己动手写评论回复,没写过还真不知道评论回复功能听着简单,但仔细研究起来却无法自拔,由于用户量少,所以...

ThinkPHP框架——实现定时任务,定时更新、清理数据

大家好,我是小蜗牛,今天给大家分享一下,如何用ThinkPHP5.1.*版本实现定时任务,例如凌晨12点更新数据、每隔10秒检测过期会员、每隔几分钟发送请求保证ip的活性等本次分享,主要用到一个名为E...

BeyongCms系统基于ThinkPHP5.1框架的轻量级内容管理系统

BeyongCms内容管理系统(简称BeyongCms)BeyongCms系统基于ThinkPHP5.1框架的轻量级内容管理系统,适用于企业Cms,个人站长等,针对移动App、小程序优化;提供完善简...

YimaoAdminv3企业建站系统,使用 thinkphp5.1.27 + mysql 开发

介绍YimaoAdminv3.0.0企业建站系统,使用thinkphp5.1.27+mysql开发。php要求5.6以上版本,推荐使用5.6,7.0,7.1,扩展(curl,...

ThinkAdmin-V5开发笔记(thinkpad做开发)

前言为了快速开发一款小程序管理后台,在众多的php开源后台中,最终选择了基于thinkphp5的,轻量级的thinkadmin系统,进行二次开发。该系统支持php7。文档地址ThinkAdmin-V5...

thinkphp5.0.9预处理导致的sql注入复现与详细分析

复现先搭建thinkphp5.0.9环境...

thinkphp5出现500错误怎么办(thinkphp页面错误)

thinkphp5出现500错误,如下图所示:相关推荐:《ThinkPHP教程》require():open_basedirrestrictionineffect.File(/home/ww...

Thinkphp5.0极速搭建restful风格接口层

下面是基于ThinkPHPV5.0RC4框架,以restful风格完成的新闻查询(get)、新闻增加(post)、新闻修改(put)、新闻删除(delete)等server接口层。1、下载Thin...

基于ThinkPHP5.1.34 LTS开发的快速开发框架DolphinPHP

DophinPHP(海豚PHP)是一个基于ThinkPHP5.1.34LTS开发的一套开源PHP快速开发框架,DophinPHP秉承极简、极速、极致的开发理念,为开发集成了基于数据-角色的权限管理机...

ThinkPHP5.*远程代码执行高危漏洞手工与升级修复解决方法

漏洞描述由于ThinkPHP5框架对控制器名没有进行足够的安全检测,导致在没有开启强制路由的情况下,黑客构造特定的请求,可直接GetWebShell。漏洞评级严重影响版本ThinkPHP5.0系列...

Thinkphp5代码执行学习(thinkphp 教程)

Thinkphp5代码执行学习缓存类RCE版本5.0.0<=ThinkPHP5<=5.0.10Tp框架搭建环境搭建测试payload...

取消回复欢迎 发表评论: