首页 >后端开发 >php教程 > 正文

详解php实现网页上一页下一页翻页过程

转载2020-08-01 16:36:5201126

前言

这几天做项目因为数据太多,需要对信息进行上下翻页展示,就自己写了翻页的代码
大致功能就是页面只显示几条信息,按上一页、下一页切换内容,当显示第一页时上一页和首页选项不可选,当页面加载到最后一页时下一页和尾页选项不可选

具体效果如下:

相关学习推荐:PHP编程从入门到精通

实现代码

1)原生PHP方法

先说一下总思路吧,首先我们要查询所有符合条件需要进行分页的总数据,计算展示的总页数。

然后获取当前显示的是第几页信息,用当前页数每页数据条数表示为总数据的第几条,再根据限制条件查询出当前页所需显示出来的数据。将每一条数据echo替换HTML结构内容中,最后显示出来

关于分页的限制条件很简单,只要查询到当前页为第1页时,首页和上一页选项跳转链接都固定在第一页同时设置选项disabled不可选,尾页也是相同的步骤。

具体代码如下:

当前页cPage需要传过来,我的办法是初始cPage=0

list.php*

<a href="listmore.php?cPage=0" rel="external nofollow" rel="external nofollow" class="pull-right">更多&gt;&gt;</a>
$row=$table->fetch()每次读取一条信息,得到的是一个索引数组,代码里的$row['id']表示$row里面名为id的值,也可表示为$row.id

connect.php(连接数据库)

<?php
$link=new PDO("mysql:host=localhost;port=3306;dbname=db","root","");
$link->query("set names utf8");

listmore.php

 <ul id="list" class="media-list">
  <?php
    include_once('connect.php');
    $result = $link->query("select * from news");
    $total=$result->rowCount();//查询出来符合条件的总数
    $pages=ceil($total/4);//分页的总页数  
    $num = 4;//每页显示的数据条数
    $cPage = $_GET['cPage'];//获取当前是显示的第几页
    $start = $cPage * $num;//第一条数据
    $table = $link->query("select * from news order by id desc limit {$start},$num");
    $link = null;//销毁
    while ($row=$table->fetch()){//每次读出一条数据,赋给$row
      //插入多行文本,把值替换掉
    echo <<<_
      <li class="media">
        <a href="detail.php?id={$row['id']}">
        <img class="pull-left" src="{$row['src']}">
        <figcaption>
        <h4><span class="title">{$row['title']}</span> <span class="news-date">{$row['time']}</span></h4>
        <p>{$row['content']}</p>
        </figcaption>
        </a>
      </li>
  _;
    }
  ?>
</ul>

上下翻页:

<p class="page text-center">
 <ul class="pagination" id="page">
  <li data-i="0" id="index" class="<?php if ($cPage==0) echo 'disabled'; ?>"><a href="listmore.php?cPage=0">&laquo;首页</a></li>
  <li data-i="1" class="<?php if ($cPage==0) echo 'disabled';?>"><a href="listmore.php?cPage=<?php echo $cPage>0?$cPage-1:0?>">&lt;上一页</a></li>
  <li data-i="2" class="<?php if ($cPage==$pages-1) echo 'disabled'?>"><a href="listmore.php?cPage=<?php echo $cPage==($pages-1)?$pages-1:$cPage+1?>">下一页&gt;</a></li>
  <li data-i="3" id="end" class="<?php if ($cPage==$pages-1) echo 'disabled'?>"><a href="listmore.php?cPage=<?php echo $pages-1?>">尾页&raquo;</a></li>
  <li class="disabled">
    <a href="##" id="total"><?php echo ($cPage+1)?>/<?php echo "$pages"?></a>
  </li>
  </ul>
</p>

2)ajax方法

HTML代码,展示信息装在panel-body里面

 <p class="panel-body" id="content">
    <ul id="list" class="media-list">  
     </ul>
  </p>
  <p class="page text-center">
     <ul class="pagination" id="page">
       <li data-i="0" id="index" class="disabled"><a href="##">&laquo;首页</a></li>
       <li data-i="1" class="disabled"><a href="##">&lt;上一页</a></li>
       <li data-i="2"><a href="##">下一页&gt;</a></li>
       <li data-i="3" id="end"><a href="##">尾页&raquo;</a></li>
       <li class="disabled">
         <a href="##" id="total"></a>
       </li>
     </ul>
   </p>
   <template id="temp">     //引用模板
    <li class="media">
      <a href="detail.html?id={id}">
        <img class="pull-left" src="{src}">
        <figcaption>
          <h4><span class="title">{title}</span> <span class="news-date">{date}</span></h4>
  
          <p>{content}</p>
         </figcaption>
        </a>
      </li>
    </template>

JS代码:

 var html=$('#temp').html();
  var curPage=0,pages=0;
  $.getJSON('php/pages.php',function (res) {
    pages=Math.ceil(res/4);/*获取信息的总页数*/
  });
  function show(cPage){//替换每一页的内容
    $.getJSON('php/listmore.php',{cPage:cPage},function (json) {
      var str='';
      $('#list').empty();
      json.forEach(function (el) {
        str+=html.replace('{id}',el.id).replace('{title}',el.title).replace('{src}',el.src)
          .replace('{content}',el.content).replace('{date}',el.time);
      });
      $('#list').html(str);
    });
    $('#total').html((curPage+1)+'/'+pages);
  }
  setTimeout(function () {
    show(0);
  },100);
  $('#page').on('click','li',function () {//上下翻页,翻遍当前页的值
    var i=$(this).data('i');//jquery里特有的获取data-*属性的方法
    switch (i){
      case 0:curPage=0;break;
      case 1:curPage>0?curPage--:0;break;
      case 2:curPage<(pages-1)?curPage++:pages-1;break;
      case 3:curPage=pages-1;break;
    }
    show(curPage);
    disabled(curPage);
  })
  function disabled(curPage) {//关于临界值禁止选择
    if (curPage==0){/*当前页为第一页,首页和上一页选项禁止点击*/
      $('#index').addClass('disabled').next().addClass('disabled');
      $('#end').removeClass('disabled').prev().removeClass('disabled');
    } else if (curPage==pages-1){
      $('#index').removeClass('disabled').next().removeClass('disabled');
      $('#end').addClass('disabled').prev().addClass('disabled');
    } else {/*当前页为最后一页,尾页和下一页选项禁止点击*/
      $('#index').removeClass('disabled').next().removeClass('disabled');
      $('#end').removeClass('disabled').prev().removeClass('disabled');
    }
  }

connect.php(连接数据库)

<?php
$link=new PDO("mysql:host=localhost;port=3306;dbname=db","root","");
$link->query("set names utf8");

pages.php(获取总页数)

<?php
include_once('connect.php');//连接数据库
$result = $link->query("select * from news");
$row=$result->rowCount();
echo $row;

listmore.php(获取数据库里的数据)

<?php
include_once ('connect.php');
$num = 4;//每一页显示的数据条数
$cPage = $_GET['cPage'];//获取当前页
$start = $cPage * $num;//计算当前页显示的第一条数据的数目
/*从表中查询从开始$start的一共$num条数据*/
$result = $link->query("select * from news order by id desc limit {$start},$num");
$link = null;
while ($row=$result->fetch()){/*每一次读取一条数据*/
$json[]=$row;/*把数据赋给json数组*/
}
echo json_encode($json);/*把json数组以json格式返回给HTML*/

以上就是详解php实现网页上一页下一页翻页过程的详细内容,更多请关注php中文网其它相关文章!

php中文网最新课程二维码
  • 相关标签:php 网页 上一页下一页翻页
  • 本文转载于:jb51,如有侵犯,请联系a@php.cn删除
  • 相关文章

    相关视频


    网友评论

    文明上网理性发言,请遵守 新闻评论服务协议

    我要评论
  • 织梦DEDE篇”效果的方法:首先进入织梦后台;然后打开对应模板文件;接着添加代码为“function nextpage(event){event = event ?
    dedecms按键盘方向键()功能的方法:首先打开“arc.archives.class.php”文件;然后替换代码为“$this->PreNext['pre']="

    2020-05-25

    933

    h5面是个自面,可以简单理个单,不h5面搭配了各种有趣的设计。h5是html5的缩写,它是html发展到第五代的通用语言。
    Ajax是指种创建交互式应用的开发技术。通在后台与服务器进行少量数据交换,Ajax可以使用异步更新。面让我们起看看它的用途。
    Ajax是指种创建交互式、快速动态应用的开发技术,无需重新加载整个的情况,能够更新部分的技术,并且可以通在后台与服务器进行少量数据交换,可以使异步更新。
    PHP+jQuery开发简单的牌抽奖例,面放置6个方块作为奖项,当抽奖者点击某块时,方块转到背面,显示中奖信息,这个奖品是随机的,不是固定的。
    这篇文章主要为大家介绍了帝国CMS自动刷新首的方法,通js调用php定时刷新首的功能,是帝国CMS二次开发中个比较典型的应用,具有定的参考借鉴价值,需要的朋友可以参考
    前端开发是创建Web面或app等前端界面呈给用户的,通HTML,CSS及JavaScript以及衍生出来的各种技术、框架、决方案,来互联产品的用户界面交互 。
    这篇文章主要介绍了PHP缓存技术优点及代码例,文中通示例代码介绍的非常细,对大家的学习或者工作具有定的参考学习价值,需要的朋友可以参考
    php工作流PHP是运行与服务器端的脚本语言,了数据库与之间的数据交互,个完整的PHP站系统由操作系统,数据库,浏览器这三部分组成。
    这篇文章主要为大家介绍了帝国CMS加入收藏与设为首的方法,可通简单的js脚本来,是很多都具备的常见功能,在使用帝国CMS建站的中非常具有用价值,需要的朋友可以参考
    这篇文章主要给大家介绍了关于利用Ajax与php数据交互并且局部刷新面的方法,文中通示例代码介绍的非常细,对大家具有定的参考学习价值,需要的朋友们面跟着小编起来学习学习吧。
    瀑布流是种很常见的布局,视觉表为参差不齐的多栏布局,是种时很流行的布局形式,最近在写小序恰好也碰到了,想了几种不同的方法,接来就来起看看具体的方法。

    2020-07-01

    186

    前端即站前台部分,是运行在PC端、移动端等浏览器给用户浏览的。前端技术般分为前端设计和前端开发,前端设计般可以理站的视觉设计,前端开发则是站的前台代码
    wps双击打开没反应的决方法:首先打开“360软件管家”,点击方的“净化”选项并点击“全面净化”方的“软件权限管理”;然后将面拉到最方,出“静默执行序”这项;最后在右边“修改权限”中将权限改为
    面由Laravel教栏目给大家介绍laravel自带分url添加参数,希望对需要的朋友有所帮助!
    在大多数的站开发中,更具际的需要,需要划分管理员和普通用户对操作站的权限。面通个具体的代码例进行全面的讲
    PHP中会话处理是个很重要的概念,它允许用户信息在站或应用序的所有保持不变。面本篇文章就来带大家学习PHP中会话处理的基础知识,希望对大家有所帮助。
    本篇文章介绍了使用LayUI轮播图的方法,具有定的参考价值,希望对学习Layui的朋友有帮助!
    有人习惯看小说,偶尔会看几章,都是百度出来,但是基本都有特别烦人的广告,要么在整体div添加链接,误触就会跳转到站甚至是死循环,某些手机app也是广告很多,所以无事在写个小序免除广告的烦扰本文将使用

    专题推荐

    作者信息

    coldplay.xixi

    好好学习 天天向上

    最近文章
    CSS面试题(参考)739
    2020 CSS3面试题823
    前端常见css的面试题目1040
    推荐视频教程
  • PHP投票系统PHP投票系统
  • PHP发送邮件功能PHP发送邮件功能
  • PHP编程词典PHP编程词典
  • PHP代码整洁之道PHP代码整洁之道
  • 视频教程分类