php+ajax實現無重新整理動態載入資料技術_php執行個體

來源:互聯網
上載者:User

我們瀏覽有些網頁的時候,當拉動瀏覽器的捲軸時到頁底時,頁面會繼續自動載入更多內容供使用者瀏覽。這種技術我暫且稱它為滾屏載入技術。我們發現很多網站用到這種技術,必應圖片搜尋、新浪微博、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資料輸出 

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

以上所述就是本文的全部內容了,希望大家能夠喜歡。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.