多数大学生出来选择的工作和专业无关
首页 > 专业知识

PHP翻页跳转功能实现方法_PHP

时间:2018-12-05 20:25:46 [来源]:郑州PHP培训学校

   PHP翻页跳转功能实现方法_PHP

  我们都知道用php+mysql在web 页实现数据库资料全部显示是非常简单而有趣的,数据库资料很少的情况下页面显示还是让人满意的,但是当数据库资料非常多的情况下,页面的显示情况将会变的非常糟糕,下面就来介绍一下如何实现当前页面数据资料显示数量及如何实现动态的翻转功能。
  这里将介绍两种翻页显示功能的实现:
  先介绍一下在翻页中用到的数据库语法:
  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<$num;$i++) {
  $val=mysql_result($result,$i,"val");
  $val1=mysql_result($result,$i,"val1");
  echo "";
  }
  }
  echo "
  翻页功能
  $val$val1
  ";
  //设置向前翻页的跳转
  $prve=$start-$limit;
  if ($prve>=0) {
  echo "prve";
  }
  //设置向后翻页的跳转
  $next=$start+$limit;
  if ($next<$num_max) {
  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;
  php+ajax实现无刷新数据分页的办法_PHP
  本文实例讲述了php+ajax实现无刷新分页的方法。分享给大家供大家参考。具体实现方法如下:
  index.php 文件,代码如下:
  <?php
  header("Content-type: text/html;charset=GBK");//输出编码,避免中文乱码?>
  <?php
  $page=isset($_GET['page'])?intval($_GET['page']):1; //这句就是获取page=18中的page的值,假如不存在page,那么页数就是1。
  $num=3; //每页显示10条数据
  $db=mysql_connect("localhost","root","123456"); //创建数据库连接mysql_select_db("demo",$db) or die("数据库链接错误"); //选择要操作的数据库mysql_query("set names gbk");
  /*
  首先咱们要获取数据库中到底有多少数据,才能判断具体要分多少页,具体的公式就是总数据库除以每页显示的条数,有余进一。
  也就是说10/3=3.3333=4 有余数就要进一。
  */
  $result=mysql_query("select * from brand");$total=mysql_num_rows($result); //查询所有的数据$url='test.php';//设置ajax提交页面地址的URL,这里设置成test.php通过ajax把参数传递给test.php再把处理过的内容赋值到本页的div id=result。
  //页码计算
  $pagenum=ceil($total/$num);//获得总页数,也是最后一页$page=min($pagenum,$page);//获得首页
  $prepg=$page-1;//
  $offset=($page-1)*$num; //获取limit的第一个参数的值,假如第一页则为(1-1)*10=0,第二页为(2-1)*10=10。
  $pagenav="
  ";
  //开始分页导航条代码:
  $pagenav.="
  显示第 ".($total?($offset+1):0)."-".min($offset+10,$total)." 条记录共 $total 条记录
  ";
  //如果只有一页则跳出函数:
  if($pagenum<=1) return false;
  $pagenav.="
  首页
  ";
  if($prepg) $pagenav.="
  前页
  "; else $pagenav.="
  前页
  ";
  if($nextpg) $pagenav.="
  后页
  "; else $pagenav.="
  后页
  ";
  $pagenav.="
  尾页
  ";
  $pagenav.="
  第 $page 页
  共 $pagenum 页
 

上一篇:做PHP网站开发需要具备哪些技能

下一篇:php实现的递归提成方案实例_PHP