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数据库初学者使用指南
Nov 16 PHP
php 修改、增加xml结点属性的实现代码
Oct 22 PHP
php下载文件源代码(强制任意文件格式下载)
May 09 PHP
PHP实现自动登入google play下载app report的方法
Sep 23 PHP
php源码分析之DZX1.5随机数函数random用法
Jun 17 PHP
Yii视图CGridView实现操作按钮定义地址示例
Jul 14 PHP
Yii2使用$this-&gt;context获取当前的Module、Controller(控制器)、Action等
Mar 29 PHP
php上传excel表格并获取数据
Apr 27 PHP
Laravel框架验证码类用法实例分析
Sep 11 PHP
PhpStorm 如何优雅的调试Hyperf的方法步骤
Nov 24 PHP
YII2框架中behavior行为的理解与使用方法示例
Mar 13 PHP
PHP8.0新功能之Match表达式的使用
Jul 19 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
dedecms中常见问题修改方法总结
2007/03/21 PHP
PHP中的正则表达式函数介绍
2012/02/27 PHP
全面解析PHP面向对象的三大特征
2017/06/10 PHP
laravel 解决Eloquent ORM的save方法无法插入数据的问题
2019/10/21 PHP
PHP基于openssl实现非对称加密代码实例
2020/06/19 PHP
$.getJSON在IE下失效的原因分析及解决方法
2013/06/16 Javascript
js的hasownproperty使用示例
2014/03/02 Javascript
JS中getYear()和getFullYear()区别分析
2014/07/04 Javascript
jQuery内置的AJAX功能和JSON的使用实例
2014/07/27 Javascript
JS回调函数的应用简单实例
2014/09/17 Javascript
jQuery插件开发的五种形态小结
2015/03/04 Javascript
深入讲解AngularJS中的自定义指令的使用
2015/06/18 Javascript
jQuery下拉美化搜索表单效果代码分享
2015/08/25 Javascript
Bootstrap 网格系统布局详解
2017/03/19 Javascript
Node.js设置CORS跨域请求中多域名白名单的方法
2017/03/28 Javascript
详解angularJS自定义指令间的相互交互
2017/07/05 Javascript
node Buffer缓存区常见操作示例
2019/05/04 Javascript
vue动态配置模板 'component is'代码
2019/07/04 Javascript
Vue使用mixin分发组件的可复用功能
2019/09/01 Javascript
Vue数据双向绑定底层实现原理
2019/11/22 Javascript
js构造函数constructor和原型prototype原理与用法实例分析
2020/03/02 Javascript
Vue双向数据绑定(MVVM)的原理
2020/10/03 Javascript
[55:16]Mski vs VGJ.S Supermajor小组赛C组 BO3 第二场 6.3
2018/06/04 DOTA
Python中的zipfile模块使用详解
2015/06/25 Python
Python爬虫入门有哪些基础知识点
2020/06/02 Python
CSS3中利用animation属性创建雪花飘落特效
2014/05/14 HTML / CSS
Get The Label中文官网:英国运动时尚购物平台
2017/04/19 全球购物
Europcar葡萄牙:葡萄牙汽车和货车租赁
2017/10/13 全球购物
保加利亚手表、香水、化妆品和珠宝购物网站:Brasty.bg
2020/04/22 全球购物
地道战观后感2000字
2015/06/04 职场文书
统招统分证明
2015/06/23 职场文书
社团招新宣传语
2015/07/13 职场文书
2015年暑期见闻
2015/07/14 职场文书
CSS3常见动画的实现方式
2021/04/14 HTML / CSS
关于使用Redisson订阅数问题
2022/01/18 Redis
十大最强奥特曼武器:怪兽战斗仪在榜,第五奥特之父只使用过一次
2022/03/18 日漫