日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > php >内容正文

php

php抓取动态数据,php+ajax实现无刷新动态加载数据技术

發布時間:2023/12/20 php 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 php抓取动态数据,php+ajax实现无刷新动态加载数据技术 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

我們瀏覽有些網頁的時候,當拉動瀏覽器的滾動條時到頁底時,頁面會繼續自動加載更多內容供用戶瀏覽。這種技術我暫且稱它為滾屏加載技術。我們發現很多網站用到這種技術,必應圖片搜索、新浪微博、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"); ?>

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

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 = "

"; var str += ""+array["date"]+""; var str += ""+array["author"]+""; var str += ""+array["content"]+""; $("#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+ajax实现无刷新动态加载数据技术的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。