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中使用Oracle数据库(1)
Oct 09 PHP
用PHP和ACCESS写聊天室(十)
Oct 09 PHP
php 提速工具eAccelerator 配置参数详解
May 16 PHP
php输出表格的实现代码(修正版)
Dec 29 PHP
PHP图片等比例缩放生成缩略图函数分享
Jun 10 PHP
PHP采集静态页面并把页面css,img,js保存的方法
Dec 23 PHP
smarty内置函数capture用法分析
Jan 22 PHP
PHP数据的提交与过滤基本操作实例详解
Nov 11 PHP
PHP文件系统管理(实例讲解)
Sep 19 PHP
PHP设计模式之注册树模式分析
Jan 26 PHP
Ajax请求PHP后台接口返回信息的实例代码
Aug 21 PHP
详解php用static方法的原因
Sep 12 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
php中XMLHttpRequest(Ajax)不能设置自定义的Referer的解决方法
2011/11/26 PHP
浅谈apache和nginx的rewrite的区别
2013/02/22 PHP
javascript入门·动态的时钟,显示完整的一些方法,新年倒计时
2007/10/01 Javascript
jQuery toggle()设置CSS样式
2009/11/05 Javascript
javascript call方法使用说明
2010/01/11 Javascript
jquery移除button的inline onclick事件(已测试及兼容浏览器)
2013/01/25 Javascript
JQuery拖动表头边框线调整表格列宽效果代码
2014/09/10 Javascript
Bootstrap打造一个左侧折叠菜单的系统模板(一)
2016/05/17 Javascript
学习vue.js表单控件绑定操作
2016/12/05 Javascript
vue动态生成dom并且自动绑定事件
2017/04/19 Javascript
使用Math.max,Math.min获取数组中的最值实例
2017/04/25 Javascript
Nodejs搭建wss服务器教程
2017/05/24 NodeJs
Vue0.1的过滤代码如何添加到Vue2.0直接使用
2017/08/23 Javascript
用JS实现根据当前时间随机生成流水号或者订单号
2018/05/31 Javascript
layui 表格的属性的显示转换方法
2018/08/14 Javascript
自定义Vue组件打包、发布到npm及使用教程
2019/05/22 Javascript
原生javascript的ajax请求及后台PHP响应操作示例
2020/02/24 Javascript
小程序选项卡以及swiper套用(跨页面)
2020/06/19 Javascript
浅谈JavaScript中this的指向更改
2020/07/28 Javascript
JS+Canvas实现五子棋游戏
2020/08/26 Javascript
Vue中使用wangeditor富文本编辑的问题
2021/02/07 Vue.js
利用Python找出序列中出现最多的元素示例代码
2017/12/08 Python
Python 数据库操作 SQLAlchemy的示例代码
2019/02/18 Python
numpy中三维数组中加入元素后的位置详解
2019/11/28 Python
Python之Class&amp;Object用法详解
2019/12/25 Python
python的help函数如何使用
2020/06/11 Python
巴西体育用品商店:Lojão dos Esportes
2018/07/21 全球购物
迎八一活动主题
2014/01/31 职场文书
中学生寄语大全
2014/04/03 职场文书
学生抄作业检讨书(2篇)
2014/10/17 职场文书
干部作风建设年活动剖析材料
2014/10/23 职场文书
2014年人力资源工作总结
2014/11/19 职场文书
辞职信格式模板
2015/02/27 职场文书
js Proxy的原理详解
2021/05/25 Javascript
Nginx配置之禁止指定IP访问
2022/05/02 Servers
python开发人人对战的五子棋小游戏
2022/05/02 Python