分享
 
 
 

学php时写的一个分页显示的类

王朝php·作者佚名  2006-01-08
窄屏简体版  字體: |||超大  

本类需在调用前应事先打开相应的数据库。

本类几乎可以实现分页显示的所有功能,首页,上一页,下一页,末页,跳转,前翻,后翻任意页,列条显示,输出文本颜色,背景色,都可自己设置,调用简单易用,今写出来供大家参考.

page.inc 分页显示的类文件

page.php 测试文件

首先需创建一个数据库,这里使用的是sale

作者: 大师 email: xyy_003@163.com

/*********************************************

以下是此分页类的所有属性:

***********************************************/

var $MaxLine; //每页显示行数

var $MaxPage; //每次显示分页数

var $Offset; //记录偏移量

var $Total; //记录总数

var $Result; //读出的结果

var $TPages; //总页数

var $CPages; //当前页数

var $Sql;//将要执行的SQL语句

var $PageQuery; //分页显示要传递的参数

var $OutPut; //输出内容

var $TextSize;//输出文字的大小

var $TextColor;//输出文字的颜色

var $InBdrColor;//输出文本框的边框颜色

var $InBgColor;//输出文本框的背景颜色

/*********************************************

以下是此分页类的所有方法:

***********************************************/

构造函数 Page($SQL,$ML,$MP,$TS,$TC,$INBDRC,$INBGC)

参数:查询的SQL语句、最大行数、每次输出的页码数、输出的文本大小、文本颜色、输入框边框原色、输入框背景原色

设置传递参数 SetPageQuery($key,$value)

参数:参数名称,参数值

读取记录,显示输出 ShowList($startpage,$t,$OF,$PHP_SELF)

参数:输出页码的最小值、何种方式跳转的标志,数据记录集的偏移量,当前文件名

此部分参数无须给定值,调用时只需延用以下变量名称即可

page.inc 类文件

<?php

/*********************************************

分页显示Mysql数据库记录的类

本类需在外部打开相应的数据库。

***********************************************/

class Page {

var $MaxLine; //每页显示行数

var $MaxPage; //每次显示分页数

var $Offset; //记录偏移量

var $Total; //记录总数

var $Result; //读出的结果

var $TPages; //总页数

var $CPages; //当前页数

var $Sql;//将要执行的SQL语句

var $PageQuery; //分页显示要传递的参数

var $OutPut; //输出内容

var $TextSize;//输出文字的大小

var $TextColor;//输出文字的颜色

var $InBdrColor;//输出文本框的边框颜色

var $InBgColor;//输出文本框的背景颜色

/******构造函数*************

参数:查询的SQL语句、最大行数、每次输出的页码数、输出的文本大小、文本颜色、输入框边框原色、输入框背景原色

***************************/

function Page($SQL,$ML,$MP,$TS,$TC,$INBDRC,$INBGC){

$this->Sql=urldecode($SQL);

$this->Sql=StripSlashes($this->Sql);

$this->MaxLine=$ML;

$this->MaxPage=$MP;

$this->TextSize=$TS;

$this->TextColor=$TC;

$this->InBdrColor=$INBDRC;

$this->InBgColor=$INBGC;

}

//******设置传递参数************

function SetPagePara($key,$value){

$tmp[key]=$key; $tmp[value]=$value;

$this->PageQuery[]=$tmp;

}

/********读取记录,显示输出***************

参数:输出页码的最小值、何种方式跳转的标志,数据记录集的偏移量,当前文件名

此部分参数无须给定值,调用时只需延用以下变量名称即可

****************************************/

function ShowList($startpage,$t,$OF,$PHP_SELF) {

if ($OF=="") $OF=0;

$this->Offset=$OF; //确定此次的偏移量

$querysql=$this->Sql;

//分情况确定输出页码的起始值

if ($t==1) {$startpage=$startpage+$this->MaxPage;$this->Offset=($startpage-1)*$this->MaxLine;}

if ($t==2) {$startpage=$startpage-$this->MaxPage;if ($startpage<1) {$startpage=1;}$this->Offset=($startpage-1)*$this->MaxLine;}

if ($t==3) {$this->Offset=($startpage-1)*$this->MaxLine;}

if ($startpage<1 or $startpage=="") $startpage=1;

//计算此次查询结果的记录条数

$result=mysql_query($querysql);

$this->Total=mysql_num_rows($result);

//把当前页的数据付给本类的对应属性,便于调用时直接使用

$sqllimit=" LIMIT ".$this->Offset." , ".$this->MaxLine;

$this->Result=mysql_query($querysql.$sqllimit);

$this->Tpages=ceil($this->Total/$this->MaxLine);

$this->CPages=$this->Offset/$this->MaxLine+1;

$querysql=urlencode($this->Sql);

//确定输出内容,并付给本类的相应属性。

$this->OutPut="<form name=\"pageform\" action=$PHP_SELF?offset=$this->Offset&querysql=$querysql><font style=\"font-size:$this->TextSize;color:$this->TextColor\">共<b> ".$this->Tpages."</b> 页/第</font><input type=\"text\" name=\"startpage\" size=\"3\" maxlength=\"4\" value=\"".$this->CPages."\" style=\"border:$this->InBdrColor 1pt solid;background-color:$this->InBgColor;height:12pt;text-align: center;color:$this->TextColor\"><font style=\"font-size:$this->TextSize;color:$this->TextColor\">页</font>&nbsp\n";

$this->OutPut.="<input type=\"hidden\" name=\"t\" value=3>";

$k=count($this->PageQuery);

//生成需传递的参数字符串或隐藏文本域

$strQuery="";

for($i=0;$i<$k;$i++){

$strQuery.="&".$this->PageQuery[$i][key]."=".$this->PageQuery[$i][value];

$this->OutPut.="<input type=\"hidden\" name=\"".$this->PageQuery[$i][key]."\" value=".$this->PageQuery[$i][value].">";

}

if ($startpage>1) {$this->OutPut.="<font style=\"font-size:$this->TextSize;color:$this->TextColor\">[<a href=$PHP_SELF?offset=$this->Offset&querysql=$querysql&startpage=$startpage&t=2$strQuery style=\"color:$this->TextColor;text-decoration:none\"><<</a>]</font>";}

for ($i=$startpage;$i<=$this->Tpages;$i++){$offset=($i-1)*$this->MaxLine; $this->OutPut.="<font style=\"font-size:$this->TextSize;color:$this->TextColor\">[<a href=$PHP_SELF?offset=$offset&querysql=$querysql&startpage=$startpage$strQuery style=\"color:$this->TextColor;text-decoration:none\">".$i."</a>] </font>";

if ($i-$startpage>$this->MaxPage-2 and $i!=$this->Tpages) {$this->OutPut.="<font style=\"font-size:$this->TextSize;color:$this->TextColor\">[<a href=$PHP_SELF?offset=$this->Offset&querysql=$querysql&startpage=$startpage&t=1$strQuery style=\"color:$this->TextColor;text-decoration:none\">>></a>]</font>";break;}}

$this->OutPut.="</form>";

}

//******end class

}

?>

/*********************************************

以下是应用词类的一段示例

***********************************************/

<?

//包含所需的头文件,打开数据库

include("include/ini_var.inc");

include("include/select_db.inc");

include("page.inc");

if ($querysql=="") $querysql=urlencode("select * from class_subject_tea where Subject_id='0'");//只需改变urlencode内的字符串即可

$pclass=new Page($querysql,5,8,"10pt","blue","black","#aaaaaa");//创建对象

$pclass->SetPagePara("para","paravalue");//设置需传递的参数,如有多个可多调用几次

$pclass->ShowList($startpage,$t,$offset,$PHP_SELF);//生成输出内容,并付给相应属性

echo $pclass->OutPut;//输出上面生成的内容

//输出当前页的数据

while($date=mysql_fetch_row($pclass->Result)){

echo "$date[1] ¦ $date[2] ¦ $date[3]<br>";

}

?>

http://coolslob.fykj.com/Favorites/CSDN2rd/408753.htm

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有