jquery瀏覽器滾動加載技術實現(xiàn)方案
要知道,數(shù)據(jù)量增加很頻繁時,要通過定位頁碼來找到目標數(shù)據(jù)似乎并沒有什么意義。我覺得用戶體驗成熟的WEB應用程序應當引導用戶使用TAG或搜索等功能來找到目標數(shù)據(jù)。至于瀏覽數(shù)據(jù),尤其是瀏覽最新的數(shù)據(jù),利用瀏覽器滾動條來加載,是很好的嘗試……
我試著用jquery來實現(xiàn)這個功能。先要得到滾動條的總長屬性值:scrollHeight,還有滾動條當前位置屬性值:scrollTop。然后通過計算,若當前值位于總長值三分之二時加載新數(shù)據(jù)。假設DOM上有一個元素為<div id=”mypage”></div>,該元素overflow樣式為scroll,也就是元素中的內(nèi)容溢出元素指定高度時啟用滾動條。利用jquery的load方法為元素加載一個已經(jīng)存在的文件,我假設它是table.html。這個文件的內(nèi)容可以是足以使瀏覽器滾屏的一張數(shù)據(jù)表。
<script type=”text/javascript” src=”jquery.js“>//加載jquery庫</script>
<script type=”text/javascript”> gh
var hght=0;//初始化滾動條總長
var top=0;//初始化滾動條的當前位置
$(document).ready(function(){//DOM的onload事件
$(”#mypage”).load(”table.html”);//table.html的內(nèi)容被加載到mypage元素
$(”#mypage”).scroll( function() {//定義滾動條位置改變時觸發(fā)的事件。
hght=this.scrollHeight;//得到滾動條總長,賦給hght變量
top=this.scrollTop;//得到滾動條當前值,賦給top變量
});
});
setInterval(”cando();”,2000);//每隔2秒鐘調(diào)用一次cando函數(shù)來判斷當前滾動條位置。
function cando(){
if(top>parseInt(hght/3)*2)//判斷滾動條當前位置是否超過總長的2/3,parseInt為取整函數(shù)
show();//如果是,調(diào)用show函數(shù)加載內(nèi)容。
}
function show(){
$.get(”table.html”, function(data){//利用jquery的get方法得到table.html內(nèi)容
$(”#mypage”).append(data);//用append方法追加內(nèi)容到mypage元素。
hght=0;//恢復滾動條總長,因為$(”#mypage”).scroll事件一觸發(fā),又會得到新值,不恢復的話可能會造成判斷錯誤而再次加載……
top=0;//原因同上。
});
}
</script>
<div id=”mypage”></div>
為什么要隔2秒鐘調(diào)用一次判斷呢?因為只要$(”#mypage”).scroll事件一被觸發(fā),就會影hght和top值,這個值可能總是滿足cando函數(shù)的判斷,也就是top值總是位于hght的三分之二。因此可能會多次加載造成服務器負擔加重。而每加載一次后把hght和top值賦0,也是這個原因。
這段代碼的效果就是只要元素mypage的滾動條位置位于滾動條總長的三分之二時,追加table.html的內(nèi)容到元素mypage中去。當然這樣運行是無休止地加載下去。在真正的AJAX運用中,table.html可以換成asp或php腳本,接收get或post參數(shù)來進行處理,然后返回有意義的數(shù)據(jù)。jquery的get方法可以設置get方式的參數(shù)數(shù)據(jù),比如:
$.get(”test.php”, { name: “boho”, id: “1″ } );
相當于http://localhost/test.php?name=boho&id=1這種形式的http訪問。然后通過get方法的回調(diào)函數(shù)來獲取test.php輸出的內(nèi)容:
$.get(”test.php”, {name:”boho”,id:”1″},function(data){
alert(”Data Loaded: ” + data);
});
相關文章
ASP.NET jQuery 實例5 (顯示CheckBoxList成員選中的內(nèi)容)
這章我們主要看下如何通過jQuery來獲取CheckBoxList成員內(nèi)容2012-01-01jq stop()和:is(:animated)的用法及區(qū)別(詳解)
下面小編就為大家?guī)硪黄猨q stop()和:is(:animated)的用法及區(qū)別(詳解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02jQuery.Form實現(xiàn)Ajax上傳文件同時設置headers的方法
這篇文章主要介紹了jQuery.Form實現(xiàn)Ajax上傳文件同時設置headers的方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-06-06IE下支持文本框和密碼框placeholder效果的JQuery插件分享
這篇文章主要介紹了IE下支持文本框和密碼框placeholder效果的JQuery插件分享,本文給出插件源碼和使用示例,需要的朋友可以參考下2015-01-01jQuery實現(xiàn)按鈕的點擊 全選/反選 單選框/復選框 文本框 表單驗證
這篇文章主要介紹了jQuery實現(xiàn)按鈕的點擊 全選/反選 單選框/復選框 文本框 表單驗證的相關資料,需要的朋友可以參考下2015-06-06