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录入页面中动态从数据库中提取数据的实现
Oct 09 PHP
php 学习资料零碎东西
Dec 04 PHP
php数组函数序列 之shuffle()和array_rand() 随机函数使用介绍
Oct 29 PHP
thinkphp中ajax与php响应过程详解
Dec 08 PHP
weiphp微信公众平台授权设置
Jan 04 PHP
php实现按天数、星期、月份查询的搜索框
May 02 PHP
php 文件下载 出现下载文件内容乱码损坏的解决方法(推荐)
Nov 16 PHP
PHP关键特性之命名空间实例详解
May 06 PHP
PHP开发中csrf攻击的简单演示和防范
May 07 PHP
基于laravel belongsTo使用详解
Oct 18 PHP
PHP的Trait机制原理与用法分析
Oct 18 PHP
php5.3/5.4/5.5/5.6/7常见新增特性汇总整理
Feb 27 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
星际争霸, 教主第一视角, ZvT经典龙蛇演义
2020/03/02 星际争霸
php实现有趣的人品测试程序实例
2015/06/08 PHP
PHP编程开发怎么提高编程效率 提高PHP编程技术
2015/11/09 PHP
php实现微信扫码支付
2017/03/26 PHP
php批量转换文件夹下所有文件编码的函数类
2017/08/06 PHP
Yii支持多域名cors原理的实现
2018/12/05 PHP
IE8 兼容性问题(属性名区分大小写)
2009/06/04 Javascript
可编辑下拉框的2种实现方式
2014/06/13 Javascript
AngularJS中的过滤器使用详解
2015/06/16 Javascript
JavaScript中this的用法实例分析
2016/12/19 Javascript
JS实现发送短信验证后按钮倒计时功能(防止刷新倒计时失效)
2017/07/07 Javascript
JS实现图片放大镜插件详解
2017/11/06 Javascript
jQuery+ajax实现动态添加表格tr td功能示例
2018/04/23 jQuery
js事件on动态绑定数据,绑定多个事件的方法
2018/09/15 Javascript
Vue2.x通用条件搜索组件的封装及应用详解
2019/05/28 Javascript
解决vue刷新页面以后丢失store的数据问题
2020/08/11 Javascript
浅谈vant组件Picker 选择器选单选问题
2020/11/04 Javascript
[00:33]2016完美“圣”典风云人物:BurNIng宣传片
2016/12/10 DOTA
在Python中使用zlib模块进行数据压缩的教程
2015/06/26 Python
在Lighttpd服务器中运行Django应用的方法
2015/07/22 Python
Python获取好友地区分布及好友性别分布情况代码详解
2019/07/10 Python
处理Selenium3+python3定位鼠标悬停才显示的元素
2019/07/31 Python
Python识别处理照片中的条形码
2020/11/16 Python
详解python中的异常和文件读写
2021/01/03 Python
萌新的HTML5 入门指南
2020/11/06 HTML / CSS
台湾旅游网站:灿星旅游
2018/10/11 全球购物
100%植物性、有机、即食餐:Sakara Life
2018/10/25 全球购物
世界上最大的皮肤科医生拥有和经营的美容网站:LovelySkin
2021/01/03 全球购物
市优秀教师事迹材料
2014/02/05 职场文书
法人代表授权委托书
2014/04/08 职场文书
文科毕业生自荐书范文
2014/04/17 职场文书
大学英语演讲稿范文
2014/04/24 职场文书
社会实践活动总结范文
2014/07/03 职场文书
小学生运动会报道稿
2014/09/12 职场文书
用基于python的appium爬取b站直播消费记录
2021/04/17 Python
MySQL聚簇索引和非聚簇索引的区别详情
2022/06/14 MySQL