国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > PHP > 正文

php+ajax實現無刷新動態加載數據技術

2024-05-04 23:34:47
字體:
來源:轉載
供稿:網友

無刷新功能我們用到很多很多的,下面我就來給各位介紹一個實例,就是實現php+ajax實現無刷新滾屏加載數據,例子非常的簡單大家只要按流程來操作就可以了哦。

我們瀏覽有些網頁的時候,當拉動瀏覽器的滾動條時到頁底時,頁面會繼續自動加載更多內容供用戶瀏覽。這種技術我暫且稱它為滾屏加載技術。我們發現很多網站用到這種技術,必應圖片搜索、新浪微博、QQ空間等將該技術應用得淋漓盡致。

滾屏加載技術,就是使用Javascript監視滾動條的位置,每次當滾動條到達瀏覽器窗口底部時,觸發一個Ajax請求后臺PHP程序,返回相應的數據,并將返回的數據追加到頁面底部,從而實現了動態加載,其實就是一個典型的Ajax應用。本文將使用jQuery,結合PHP,mysql以及JSON,為您講解如何應用滾屏加載技術到您的項目中去。當然,閱讀本文的前提是您需要有jQuery和PHP相關基礎。

index.php

我們默認要顯示15條數據,因此,我們先從數據庫取開始的15條數據顯示在頁面。后面新加載的數據,我們也按每次15條的方式展示。

為了講解盡量簡單,我使用原生的PHP和mysql查詢語句。首先,需要連接數據庫,包含連接信息的connnect.php。這里我定義了幾個用戶id。

然后查詢數據表,獲得結果集,并循環輸出,代碼如下:

 

 
  1. <?php  
  2. require_once('connect.php');  
  3. $user = array('demo1','demo2','demo3','demo3','demo4');  
  4. ?>  
  5. <div id="container">  
  6. <?php  
  7. $query=mysql_query("select * from say order by id desc limit 0,15");  
  8. while ($row=mysql_fetch_array($query)) {  
  9. ?>  
  10. <div class="single_item">  
  11. <div class="element_head">  
  12. <div class="date"><?php echo date('m-d H:i',$row['addtime']);?></div>  
  13. <div class="author"><?php echo $user[$row['userid']];?></div>  
  14. </div>  
  15. <div class="content"><?php echo $row['content'];?></div>  
  16. </div>  
  17. <?php } ?>  
  18. </div>  
  19. <div class="nodata"></div>  

注:本例使用的數據來源于本站文章:,文中有創建數據表的介紹。

jQuery

1、首先,我們要獲取瀏覽器可視區域頁面的高度:

復制代碼代碼如下:

var winH = $(window).height();

2、然后,當滾動頁面的時候需要做的事情是:計算頁面總高度(當滾動底部時,頁面新加載數據,所以頁面總高度是動態變化的),計算滾動條位置(滾動條位置也是隨著加載頁面的高度動態變化的),然后構造一個公式,計算相對比例。

 

 
  1. $(window).scroll(function () {  
  2. var pageH = $(document.body).height(); //頁面總高度  
  3. var scrollT = $(window).scrollTop(); //滾動條top  
  4. var aa = (pageH-winH-scrollT)/winH;  
  5. });  

3、當滾動條接近頁底時,觸發ajax加載,在本例中我們使用jQuery的getJSON方法,向服務端result.php發送請求,請求的參數為page,即頁數。

 

 
  1. if(aa<0.02){  
  2. $.getJSON("result.php",{page:i},function(json){  
  3. .....  
  4. });  
  5. }  

4、如果請求響應成功返回JSON數據,則解析JSON數據,并將數據追加到頁面DIV#container后,如果沒有JSON數據返回,則說明數據全部顯示完畢

 

 
  1. if(json){  
  2. var str = "";  
  3. $.each(json,function(index,array){ //遍歷  
  4. var str = "..."//獲取的JSON數據  
  5. $("#container").append(str); //追加  
  6. });  
  7. i++; //頁數+1  
  8. }else{  
  9. $(".nodata").show().html("別滾動了,已經到底了。。。");  
  10. return false;  
  11. }  

完整的jQuery代碼如下:

 

 
  1. $(function(){  
  2. var winH = $(window).height(); //頁面可視區域高度  
  3. var i = 1; //設置當前頁數  
  4. $(window).scroll(function () {  
  5. var pageH = $(document.body).height();  
  6. var scrollT = $(window).scrollTop(); //滾動條top  
  7. var aa = (pageH-winH-scrollT)/winH;  
  8. if(aa<0.02){  
  9. $.getJSON("result.php",{page:i},function(json){  
  10. if(json){  
  11. var str = "";  
  12. $.each(json,function(index,array){  
  13. var str = "<div class=/"single_item/"><div class=/"element_head/">";  
  14. var str += "<div class=/"date/">"+array['date']+"</div>";  
  15. var str += "<div class=/"author/">"+array['author']+"</div>";  
  16. var str += "</div><div class=/"content/">"+array['content']+"</div></div>";  
  17. $("#container").append(str);  
  18. });  
  19. i++;  
  20. }else{  
  21. $(".nodata").show().html("別滾動了,已經到底了。。。");  
  22. return false;  
  23. }  
  24. });  
  25. }  
  26. });  
  27. });  

result.php

當滾動到頁面底部時,前端Ajax請求到result.php,該后臺程序將根據請求的數據頁數:page,查詢數據表中對應的記錄,并將記錄集以json的格式輸出返回給前端處理。

 

 
  1. require_once('connect.php'); //連接數據庫  
  2.  
  3. $user = array('demo1','demo2','demo3','demo3','demo4');  
  4. $page = intval($_GET['page']); //獲取請求的頁數  
  5. $start = $page*15;  
  6. $query=mysql_query("select * from say order by id desc limit $start,15");  
  7. while ($row=mysql_fetch_array($query)) {  
  8. $arr[] = array(  
  9. 'content'=>$row['content'],  
  10. 'author'=>$user[$row['userid']],  
  11. 'date'=>date('m-d H:i',$row['addtime'])  
  12. );  
  13. }  
  14. echo json_encode($arr); //轉換為json數據輸出  

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

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 利辛县| 三台县| 宝应县| 隆德县| 卫辉市| 德令哈市| 康保县| 湘潭市| 马龙县| 常德市| 辰溪县| 子长县| 乌兰察布市| 隆林| 乡宁县| 通河县| 西畴县| 淮滨县| 西贡区| 百色市| 宜春市| 铜山县| 通城县| 满洲里市| 扬州市| 慈利县| 楚雄市| 大方县| 古浪县| 安徽省| 澄迈县| 甘孜县| 金塔县| 静宁县| 桐柏县| 绍兴县| 榕江县| 沛县| 孝义市| 阿尔山市| 双鸭山市|