All articles| All Pictures| All Softwares| All Video| Go home page| Write articles| Upload pictures

Reading number is top 10 articles
delphi类的定义以及类中的保留字
Karrigell,入门_php资料_编程技术
SQLServer分页查询通用存储过程_[SQL Server教程]
解决SqlTransaction用尽的问题(SQL处理超时)_[SQL,Server教程]
C#教程:MouseClick和MouseDoubleClick事件使用实例
利用XML实现通用WEB报表打印实际使用中的例子_[XML教程]
通过实例学习C#开发中的泛型_.net资料_编程技术
vbscript下将小写金额转成大写金额_JavaScript技术_编程技术
ASP.NET自动识别GB2312与UTF-8编码的文件_.net资料_编程技术
PHP脚本编程中的文件系统函数库_php资料_编程技术
Reading number is top 10 pictures
The money of more than 100 countries and regions18
Ashlynn Brooke show proud chest measurement1
乳娘帕梅拉安德森5
Beauty shocked Japan Tokyo motor show model
西游四格漫画(三)
Street street fighting
锄禾日了几个人?
看看什么叫美景
The world first motorcycle will be auctioned for 21000 pounds
Li Zongrui hunting video screenshots1
Download software ranking
Unix video tutorial5
Kung.Fu.Panda.2
Visual C++界面编程技术
Macromedia Dreamweaver 8
金山office2007
打鸟视频
Dance with duck(male prostitution)
Eclipse 4.2.2 For Win64
在线棋牌游戏3.05版
Boxer's Top ten classic battle4
归海一刀 published in(发表于) 2014/2/10 6:55:49 Edit(编辑)
自定义PHP分页函数_[PHP教程]

自定义PHP分页函数_[PHP教程]

自定义PHP分页函数_[PHP教程]

每次编写列表性质的页面,几乎都要写上一段分页的程序。最近小阳终于决心一劳永逸——自定义一个分页函数,并保存在“pageft.php”文件里。要用到分页的地方,就直接包含“pageft.php”文件,并调用这个函数就行了。小阳在编写这个函数时,尽量注意了程序的可移植性和易用性,下面就是小阳编写的函数:

//为了避免重复包含文件而造成错误,加了判断函数是否存在的条件:
if(!function_exists(pageft)){
//定义函数pageft(),三个参数的含义为:
//totle:信息总数;
//displaypg:每页显示信息数,这里设置为默认是20;
//url:分页导航中的链接,除了加入不同的查询信息“page”外的部分都与这个URL相同。
//   默认值本该设为本页URL(即_SERVER["REQUEST_URI"]),但设置默认值的右边只能为常量,所以该默认值设为空字符串,在函数内部再设置为本页URL。
function pageft(totle,displaypg=20,url=''){


//定义几个全局变量:
//page:当前页码;
//firstcount:(数据库)查询的起始项;
//pagenav:页面导航条代码,函数内部并没有将它输出;
//_SERVER:读取本页URL“_SERVER["REQUEST_URI"]”所必须。
global page,firstcount,pagenav,_SERVER;


//为使函数外部可以访问这里的“displaypg”,将它也设为全局变量。注意一个变量重新定义为全局变量后,原值被覆盖,所以这里给它重新赋值。
GLOBALS["displaypg"]=displaypg;


if(!page) page=1;


//如果url使用默认,即空值,则赋值为本页URL:
if(!url){ url=_SERVER["REQUEST_URI"];}


//URL分析:
parse_url=parse_url(url);
url_query=parse_url["query"]; //单独取出URL的查询字串
if(url_query){
//因为URL中可能包含了页码信息,我们要把它去掉,以便加入新的页码信息。
//这里用到了正则表达式,请参考“PHP中的正规表达式”(http://www.webjx.com/htmldata/2005-02-25/1109263261.html
url_query=ereg_replace("(^|&)page=page","",url_query);


//将处理后的URL的查询字串替换原来的URL的查询字串:
url=str_replace(parse_url["query"],url_query,url);


//在URL后加page查询信息,但待赋值:
if(url_query) url.="&page"; else url.="page";
}else {
url.="?page";
}


页码计算:
lastpg=ceil(totle/displaypg); //最后页,也是总页数
page=min(lastpg,page);
prepg=page-1; //上一页
nextpg=(page==lastpg ? 0 : page+1); //下一页
firstcount=(page-1)*displaypg;


//开始分页导航条代码:
pagenav="显示第 ".(totle?(firstcount+1):0)."-".min(firstcount+displaypg,totle)." 条记录,共 totle 条记录
";


//如果只有一页则跳出函数:
if(lastpg<=1) return false;


pagenav.=" 首页 ";
if(prepg) pagenav.=" 前页 "; else pagenav.=" 前页 ";
if(nextpg) pagenav.=" 后页 "; else pagenav.=" 后页 ";
pagenav.=" 尾页 ";


//下拉跳转列表,循环列出所有页码:
pagenav.=" 到第 页,共 lastpg 页";
}
}
?>


好,分页函数已经写好了,保存为“pageft.php”,要分页时就包含它并调用pageft()函数。不过它并没有输出任何东西,但产生几个全局变量供使用:firstcount、displaypg、pagenav。


下面举例说明它的用法:


//(前面程序略)
include("pageft.php"); //包含“pageft.php”文件
//取得总信息数
result=mysql_query("select * from mytable");
total=mysql_num_rows(result);
//调用pageft(),每页显示10条信息(使用默认的20时,可以省略此参数),使用本页URL(默认,所以省略掉)。
pageft(total,10);
//现在产生的全局变量就派上用场了:
result=mysql_query("select * from mytable limit firstcount,displaypg ");
while(row=mysql_fetch_array(result)){
//(列表内容略)
}


//输出分页导航条代码:
echo pagenav;


//(后面程序略)
?>


下图即为导航条格式显示的效果:








添加到del.icio.us 添加到新浪ViVi 添加到百度搜藏 添加到POCO网摘 添加到天天网摘365Key 添加到和讯网摘 添加到天极网摘 添加到黑米书签 添加到QQ书签 添加到雅虎收藏 添加到奇客发现 diigo it 添加到饭否 添加到飞豆订阅 添加到抓虾收藏 添加到鲜果订阅 digg it 貼到funP 添加到有道阅读 Live Favorites 添加到Newsvine 打印本页 用Email发送本页 在Facebook上分享


Disclaimer Privacy Policy About us Site Map

If you have any requirements, please contact webmaster。(如果有什么要求,请联系站长)
Copyright ©2011-
uuhomepage.com, Inc. All rights reserved.