php上下翻页,怎么在PHP项目中实现一个翻页跳转功能

怎么在PHP项目中实现一个翻页跳转功能

发布时间:2020-12-19 16:09:54

来源:亿速云

阅读:73

作者:Leah

怎么在PHP项目中实现一个翻页跳转功能?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

两种翻页显示功能的实现:

先介绍一下在翻页中用到的数据库语法:mysql_query("select * from table order by id desc");

这条数据库语句再熟悉不过了,是用来搜索记录并倒序地显示出来,但并不能在翻页功能中起作用,而下面这个扩展了的语法才是实现翻页的核心功能:mysql_query("select * from table order by id desc limit $start,$limit");

这里的 $start 是数据库搜索的起始行,$limit 是从起始行开始搜索到 $limit 条记录结束,好了,有了这个核心功能后,我们可以开始翻页功能了。

第一种翻页功能:这里介绍的功能是翻页功能中最简单的一种,只能实现向前翻页和向后翻页,本站的非常新闻和下载中心的翻页功能就是这种。

先介绍翻页功能实现的思路:先确定当前页固定显示的数据记录数量,假设为 20 条记录,设定 $limit 的值为 20: $limit=20;

显示数据库记录时,必须是从第一条开始显示,所以这里设置 $start 的初始值为 0:$start=0;

翻页功能的实现依赖 $start 的动态变化,当向后翻页时 $start 规律地加上 $limit:$start+$limit;而向前翻页时 $start 则规律地减去 $limit:$start-$limit;

有了以上的思路后,可以开始设计程序了

page.php:

//设置当前页显示的数量(这个数量可任意设置)

$limit=20;

//初始化数据库搜索起始记录

if (!emptyempty($start)) $start=0;

mysql_connect("localhost","","");

mysql_select_db(database);

//设置数据库记录总数

$result=mysql_query("select * from table");

$num_max=mysql_numrows($result);

$result=mysql_query("select * from table order by id desc limit $start,$limit);

$num=mysql_numrows($result);

echo "

翻页功能

if (!emptyempty($num)) {

for ($i=0;$i

$val=mysql_result($result,$i,"val");

$val1=mysql_result($result,$i,"val1");

echo "

$val$val1";

}

}

echo "

";

//设置向前翻页的跳转

$prve=$start-$limit;

if ($prve>=0) {

echo "prve";

}

//设置向后翻页的跳转

$next=$start+$limit;

if ($next

echo "next";

}

echo "

";

?>

一个前翻,后翻功能的程序完成了,但这个功能对处理更多资料显示时,将会显得很累赘.下面将会继续介绍功能更强大,更加复杂的翻页功能--循环翻页(我一直都这么叫,因为找不到更合适的叫法).:)

前面介绍了简单的翻页功能实现,下面介绍的翻页功能更加强大,更加复杂,本站的非常论坛和非常文章就是使用这个循环翻页功能的.

循环翻页是前翻后翻加上数字共同实现的,具体的表现形式为:

页: prve <<1 2 3 4 ....... 20 >> next

里面的数字表示各当前的页面,前翻 prve 和后翻 next 已不仅仅是当前页的前后翻转,而是更加复杂的数字控制前后翻转。

同以往一样,在进行程序设计之前,先理清一下思路,我建议读者在看完如何实现循环翻页的功能后,能自己动手实践一次,因为这里研究的一些方法和思路可能比较抽象。

首先我们大胆假设数据库里存有超过1000 条的记录,我们希望当前显示 25 条记录,而数字翻转控制为 20,因此就有如下的显示结果:

页: 0 1 2 3 ......... 19 >> next

后翻后的显示结果:

页: prve <<20 27 28 ....... 49 >> next好,我们来看看其中的规律,一个固定的显示数字 25 ,一个固定的数字控制倍翻 20.我们可以利用这两个数字来实现循环翻页功能;

首先设置固定显示的变量:

$limit=20;

数据库初始变量的设置:

$start=0;

数据库记录总数为:

$num;

页数变量:$page;

一个页数循环显示的程序如下:

...

$result=mysql_query("select * from table");

$num=mysql_numrows($result);

for ($page=0;$page

echo $page;

if ($page>0 && ($page%20)==0) {

break; //退出循环

}

}

?>

这段代码除了显示数字外,其它功能一概没有实现,因为多了数字控制翻转,所以必须要有几个变量来标记并识别这些控制量,这里用了$s 来标记,这个变量是用来控制数字循环翻页控制的,现在可以看看实现循环翻页的完整代码page.php:

$limit=25;

if (!emptyempty($start)) $start=0;

if (!emptyempty($s)) $s=0;

mysql_connect("localhost","","");

mysql_select_db(database);

//统计数据库记录总数

$result=mysql_query("select * from table");

$num=mysql_numrows($result);

$result=mysql_query("select * from table order by id limit $start,$limit");

$numb=mysql_numrows($result);

echo "

if (!emptyempty($numb)) {

for($i=0;$i

$val=mysql_result($result,$i,"val");

$val1=mysql_result($result,$i,"val1");

echo "

$val$val1";

}

}

echo "

";

//数字循环翻页的控制

echo "

echo "

页:";

//前翻控制

if ($s>20) {

if ($s==21) {

$st=$s-21;

} else {

$st=$s-20;

}

$pstart=$st*$limit;

echo "

echo "start=$pstart&s=$st>prve

";

}

echo "

 >>";

//设置当前页对应页数无链接功能

$star=$start;

//注意循环的初始附值,仔细想想为什么不是 0

for ($page=$s;$page

$start=$page*$limit;

echo "

";

if($page!=$star/$limit) {

echo "

echo "start=$start&s=$s>";

}

echo $page;

if($page!=$star/$limit) {

echo "

";

}

echo "

";

//控制数字页面限制显示功能,控制只显示 20 页

if ($page>0 && ($page%20)==0) {

if ($s==0) {

$s=$s+21;

} else {

$s=$s+20;

}

$start=$start+$limit;

if ((($num/$limit)-1)>$page) {

echo "

 <<

echo "start=$start&s=$s>next

";

}

//注意跳出循环的控制

break;

}

}

echo "

";

?>

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值