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 相关文章推荐
从一个不错的留言本弄的mysql数据库操作类
Sep 02 PHP
php 什么是PEAR?
Mar 19 PHP
PHP 远程文件管理,可以给表格排序,遍历目录,时间排序
Aug 07 PHP
php5.3提示Function ereg() is deprecated Error问题解决方法
Nov 12 PHP
php获取随机数组列表的方法
Nov 13 PHP
PHP将HTML转换成文本的实现代码
Jan 21 PHP
Yii中Model(模型)的创建及使用方法
Dec 28 PHP
yii2.0数据库迁移教程【多个数据库同时同步数据】
Oct 08 PHP
PHP实现针对日期,月数,天数,周数,小时,分,秒等的加减运算示例【基于strtotime】
Apr 19 PHP
PHP实现简单的模板引擎功能示例
Sep 02 PHP
php微信开发之音乐回复功能
Jun 14 PHP
laravel框架中视图的基本使用方法分析
Nov 23 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
论建造顺序的重要性
2020/03/04 星际争霸
PHP自动生成月历代码
2006/10/09 PHP
main.php
2006/12/09 PHP
php adodb连接mssql解决乱码问题
2009/06/12 PHP
PHP基础陷阱题(变量赋值)
2012/09/12 PHP
PHP base64编码后解码乱码的解决办法
2014/06/19 PHP
ThinkPHP3.2.2的插件控制器功能
2015/03/05 PHP
Symfony的安装和配置方法
2016/03/17 PHP
Yii数据读取与跳转参数传递用法实例分析
2016/07/12 PHP
PHP数组式访问接口ArrayAccess用法分析
2017/12/28 PHP
setTimeout和setInterval的浏览器兼容性分析
2007/02/27 Javascript
js判断运行jsp页面的浏览器类型以及版本示例
2013/10/30 Javascript
javascript强制点击广告的方法
2015/02/06 Javascript
解决webpack多页面内存溢出的方法示例
2019/10/08 Javascript
[02:49]DAC2018决赛日TOP5 LGD开启黑暗之门绝杀VP
2018/04/08 DOTA
python client使用http post 到server端的代码
2013/02/10 Python
Python制作CSDN免积分下载器
2015/03/10 Python
Python中的filter()函数的用法
2015/04/27 Python
Python发送form-data请求及拼接form-data内容的方法
2016/03/05 Python
Python Paramiko模块的安装与使用详解
2016/11/18 Python
Python入门之三角函数atan2()函数详解
2017/11/08 Python
python实现ip代理池功能示例
2019/07/05 Python
pytorch 实现在一个优化器中设置多个网络参数的例子
2020/02/20 Python
python 实现在无序数组中找到中位数方法
2020/03/03 Python
PyCharm+Pipenv虚拟环境开发和依赖管理的教程详解
2020/04/16 Python
css3新单位vw、vh的使用教程
2018/03/23 HTML / CSS
html5使用Drag事件编辑器拖拽上传图片的示例代码
2017/08/22 HTML / CSS
Kipling凯浦林美国官网:世界著名时尚休闲包袋品牌
2016/08/24 全球购物
什么是封装
2013/03/26 面试题
会议邀请函范文
2014/01/09 职场文书
商场中秋节广播稿
2014/01/17 职场文书
民警个人对照检查剖析材料
2014/09/17 职场文书
XX部保密工作制度范本
2019/08/27 职场文书
pytorch交叉熵损失函数的weight参数的使用
2021/05/24 Python
PO模式在selenium自动化测试框架的优势
2022/03/20 Python
python 判断字符串当中是否包含字符(str.contain)
2022/06/01 Python