php+ajax实现无刷新动态加载数据技术


Posted in PHP onApril 28, 2015

我们浏览有些网页的时候,当拉动浏览器的滚动条时到页底时,页面会继续自动加载更多内容供用户浏览。这种技术我暂且称它为滚屏加载技术。我们发现很多网站用到这种技术,必应图片搜索、新浪微博、QQ空间等将该技术应用得淋漓尽致。

滚屏加载技术,就是使用Javascript监视滚动条的位置,每次当滚动条到达浏览器窗口底部时,触发一个Ajax请求后台PHP程序,返回相应的数据,并将返回的数据追加到页面底部,从而实现了动态加载,其实就是一个典型的Ajax应用。本文将使用jQuery,结合PHP,mysql以及JSON,为您讲解如何应用滚屏加载技术到您的项目中去。当然,阅读本文的前提是您需要有jQuery和PHP相关基础。

index.php

我们默认要显示15条数据,因此,我们先从数据库取开始的15条数据显示在页面。后面新加载的数据,我们也按每次15条的方式展示。

为了讲解尽量简单,我使用原生的PHP和mysql查询语句。首先,需要连接数据库,包含连接信息的connnect.php。这里我定义了几个用户id。

然后查询数据表,获得结果集,并循环输出,代码如下:

<?php 
require_once('connect.php'); 
$user = array('demo1','demo2','demo3','demo3','demo4'); 
?> 
<div id="container"> 
  <?php 
  $query=mysql_query("select * from say order by id desc limit 0,15"); 
  while ($row=mysql_fetch_array($query)) { 
  ?> 
  <div class="single_item"> 
    <div class="element_head"> 
       <div class="date"><?php echo date('m-d H:i',$row['addtime']);?></div> 
       <div class="author"><?php echo $user[$row['userid']];?></div> 
     </div> 
     <div class="content"><?php echo $row['content'];?></div> 
  </div> 
  <?php } ?> 
 </div> 
<div class="nodata"></div>

注:本例使用的数据来源于本站文章:,文中有创建数据表的介绍。

jQuery

1、首先,我们要获取浏览器可视区域页面的高度:

var winH = $(window).height();

2、然后,当滚动页面的时候需要做的事情是:计算页面总高度(当滚动底部时,页面新加载数据,所以页面总高度是动态变化的),计算滚动条位置(滚动条位置也是随着加载页面的高度动态变化的),然后构造一个公式,计算相对比例。

$(window).scroll(function () { 
  var pageH = $(document.body).height(); //页面总高度 
  var scrollT = $(window).scrollTop(); //滚动条top 
  var aa = (pageH-winH-scrollT)/winH; 
});

3、当滚动条接近页底时,触发ajax加载,在本例中我们使用jQuery的getJSON方法,向服务端result.php发送请求,请求的参数为page,即页数。

if(aa<0.02){ 
  $.getJSON("result.php",{page:i},function(json){ 
    ..... 
  }); 
 }

4、如果请求响应成功返回JSON数据,则解析JSON数据,并将数据追加到页面DIV#container后,如果没有JSON数据返回,则说明数据全部显示完毕

if(json){ 
  var str = ""; 
  $.each(json,function(index,array){ //遍历 
    var str = "..."; //获取的JSON数据 
    $("#container").append(str); //追加 
  }); 
  i++; //页数+1 
}else{ 
  $(".nodata").show().html("别滚动了,已经到底了。。。"); 
  return false; 
}

完整的jQuery代码如下:

$(function(){ 
  var winH = $(window).height(); //页面可视区域高度 
  var i = 1; //设置当前页数 
  $(window).scroll(function () { 
    var pageH = $(document.body).height(); 
    var scrollT = $(window).scrollTop(); //滚动条top 
    var aa = (pageH-winH-scrollT)/winH; 
    if(aa<0.02){ 
      $.getJSON("result.php",{page:i},function(json){ 
        if(json){ 
          var str = ""; 
          $.each(json,function(index,array){ 
            var str = "<div class=\"single_item\"><div class=\"element_head\">"; 
            var str += "<div class=\"date\">"+array['date']+"</div>"; 
            var str += "<div class=\"author\">"+array['author']+"</div>"; 
            var str += "</div><div class=\"content\">"+array['content']+"</div></div>"; 
            $("#container").append(str); 
          }); 
          i++; 
        }else{ 
          $(".nodata").show().html("别滚动了,已经到底了。。。"); 
          return false; 
        } 
      }); 
    } 
  }); 
});

result.php

当滚动到页面底部时,前端Ajax请求到result.php,该后台程序将根据请求的数据页数:page,查询数据表中对应的记录,并将记录集以json的格式输出返回给前端处理。

require_once('connect.php'); //连接数据库 
 
$user = array('demo1','demo2','demo3','demo3','demo4'); 
$page = intval($_GET['page']); //获取请求的页数 
$start = $page*15; 
$query=mysql_query("select * from say order by id desc limit $start,15"); 
while ($row=mysql_fetch_array($query)) { 
  $arr[] = array( 
    'content'=>$row['content'], 
    'author'=>$user[$row['userid']], 
    'date'=>date('m-d H:i',$row['addtime']) 
  ); 
} 
echo json_encode($arr); //转换为json数据输出

好了,本文的介绍到此结束,快去看看效果吧。

以上所述就是本文的全部内容了,希望大家能够喜欢。

PHP 相关文章推荐
php 设计模式之 单例模式
Dec 19 PHP
深入php函数file_get_contents超时处理的方法详解
Jun 03 PHP
phpexcel导入excel数据使用方法实例
Dec 24 PHP
php数据库备份还原类分享
Mar 20 PHP
php实现建立多层级目录的方法
Jul 19 PHP
php动态绑定变量的用法
Jun 16 PHP
PHP 获取ip地址代码汇总
Jul 05 PHP
详解WordPress中过滤链接与过滤SQL语句的方法
Dec 18 PHP
PHP共享内存用法实例分析
Feb 12 PHP
PHP记录页面停留时间的方法
Mar 30 PHP
PHP获取当前执行php文件名的代码
Mar 02 PHP
PHP实现图的邻接矩阵表示及几种简单遍历算法分析
Nov 24 PHP
php恢复数组的key为数字序列的方法
Apr 28 #PHP
php递归调用删除数组空值元素的方法
Apr 28 #PHP
php删除文本文件中重复行的方法
Apr 28 #PHP
php实现简单的语法高亮函数实例分析
Apr 27 #PHP
php转换颜色为其反色的方法
Apr 27 #PHP
PHP结合jQuery.autocomplete插件实现输入自动完成提示的功能
Apr 27 #PHP
PHP+jQuery+Ajax实现用户登录与退出
Apr 27 #PHP
You might like
BBS(php &amp; mysql)完整版(七)
2006/10/09 PHP
PHP5与MySQL数据库操作常用代码 收集
2010/03/21 PHP
UCenter中的一个可逆加密函数authcode函数代码
2010/07/20 PHP
Laravel 4 初级教程之安装及入门
2014/10/30 PHP
利用laravel搭建一个迷你博客实战教程
2017/08/13 PHP
[原创]PHP实现生成vcf vcard文件功能类定义与使用方法详解【附demo源码下载】
2017/09/02 PHP
javascript 对象定义方法 简单易学
2009/03/22 Javascript
Javascript 面向对象 命名空间
2010/05/13 Javascript
Nodejs使用mysql模块之获得更新和删除影响的行数的方法
2014/03/18 NodeJs
深入浅析react native es6语法
2015/12/09 Javascript
JavaScript每天必学之基础知识
2016/09/17 Javascript
jQuery使用方法
2017/02/04 Javascript
JavaScript结合HTML DOM实现联动菜单
2017/04/05 Javascript
JQuery EasyUI 结合ztrIee的后台页面开发实例
2017/09/01 jQuery
Angularjs实现上传图片预览功能
2017/09/01 Javascript
JavaScript继承定义与用法实践分析
2018/05/28 Javascript
vue项目持久化存储数据的实现代码
2018/10/01 Javascript
jQuery实现的3D版图片轮播示例【滑动轮播】
2019/01/18 jQuery
微信小程序调用天气接口并且渲染在页面过程详解
2019/06/24 Javascript
ES6如何用一句代码实现函数的柯里化
2020/01/18 Javascript
JS实现省市县三级下拉联动
2020/04/10 Javascript
[02:57]DOTA2亚洲邀请赛 SECRET战队出场宣传片
2015/02/07 DOTA
Python设计模式之代理模式实例
2014/04/26 Python
Python实现的排列组合、破解密码算法示例
2019/04/12 Python
Python线上环境使用日志的及配置文件
2019/07/28 Python
浅析Python 条件控制语句
2020/07/15 Python
比较一下entity bean和session bean
2013/12/27 面试题
物理系毕业生自荐信
2013/11/01 职场文书
小区消防演习方案
2014/02/21 职场文书
安全教育演讲稿
2014/05/09 职场文书
民事授权委托书范文
2014/08/02 职场文书
一年级语文上册复习计划
2015/01/17 职场文书
拾金不昧感谢信范文
2015/01/21 职场文书
公司地址变更通知
2015/04/25 职场文书
为什么MySQL选择Repeatable Read作为默认隔离级别
2021/07/26 MySQL
mysql使用FIND_IN_SET和group_concat两个方法查询上下级机构
2022/04/20 MySQL