js實(shí)現(xiàn)滾動(dòng)條滾動(dòng)到頁(yè)面底部繼續(xù)加載
這個(gè)實(shí)例應(yīng)該說(shuō)可以很簡(jiǎn)單,直接使用jQuery的方法來(lái)處理也是可以的。但本文底層使用原生的js來(lái)處理,遇到一些小知識(shí)點(diǎn)可以分析一下也算有所得。
原理很簡(jiǎn)單,就是為window添加一個(gè)scroll事件,瀏覽器每次觸發(fā)scroll事件時(shí)判斷是否滾動(dòng)到了瀏覽器底部,如果到了底部則加載新數(shù)據(jù)。關(guān)鍵是計(jì)算滾動(dòng)條是否滾動(dòng)到了瀏覽器底部,算法如下
滾動(dòng)條卷起來(lái)的高度 + 窗口高度 > 文檔的總高度 + 50/*我這里將滾動(dòng)響應(yīng)區(qū)域高度取50px*/;如果這個(gè)判斷為true則表示滾動(dòng)條滾動(dòng)到了底部。
實(shí)例
<style type="text/css"> html,body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, code, form, fieldset, legend, input, button, textarea, p, blockquote, th, td{ margin: 0; padding:0; } *{ -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; } .waterfllow-loading{ z-index: 2000; display:none; } .waterfllow-loading.active{ display:block; } .waterfllow-loading img.loading-progress{ position: fixed; /*設(shè)置等待條水平居于窗口正中*/ margin-left: auto; margin-right: auto; left: 0; right: 0; /*不能設(shè)置margin-top:auto和margin-bottom:auto否則IE下bottom就不頂用了*/ bottom: 30px; } </style> <div class="waterfllow-loading"> <img class="loading-progress" src="busy.gif"> </div> <script type="text/javascript"> //圖片查詢中正對(duì)瀏覽器主頁(yè)面滾動(dòng)事件處理(瀑布流)。只能使用window方式綁定,使用document方式不起作用 $(window).on('scroll',function(){ if(scrollTop() + windowHeight() >= (documentHeight() - 50/*滾動(dòng)響應(yīng)區(qū)域高度取50px*/)){ waterallowData(); } }); function waterallowData(){ $('.waterfllow-loading').addClass('active'); /*$.ajax({ url:url, type:"post", data: params, success:function(data,textStatus,jQXHR){ //添加數(shù)據(jù) ... //隱藏加載條 $('.waterfllow-loading.active').removeClass('active'); } });*/ }
獲取頁(yè)面頂部被卷起來(lái)的高度函數(shù)
//獲取頁(yè)面頂部被卷起來(lái)的高度 function scrollTop(){ return Math.max( //chrome document.body.scrollTop, //firefox/IE document.documentElement.scrollTop); }
chrome瀏覽器和Firefox/IE對(duì)滾動(dòng)條是屬于body還是html理解不同導(dǎo)致處理不同。
獲取頁(yè)面文檔的總高度
//獲取頁(yè)面文檔的總高度 function documentHeight(){ //現(xiàn)代瀏覽器(IE9+和其他瀏覽器)和IE8的document.body.scrollHeight和document.documentElement.scrollHeight都可以 return Math.max(document.body.scrollHeight,document.documentElement.scrollHeight); }
這個(gè)算法和jQuery計(jì)算文檔高度的方法一致。
獲取頁(yè)面瀏覽器視口的高度
function windowHeight(){ return (document.compatMode == "CSS1Compat")? document.documentElement.clientHeight: document.body.clientHeight; }
這里需要說(shuō)明的是document.compatMode這個(gè)東東。很陌生,一般情況貌似沒(méi)有遇到過(guò)。
document.compatMode有兩個(gè)取值"BackCompat"和"CSS1Compat"。官方解釋是BackCompat:標(biāo)準(zhǔn)兼容模式關(guān)閉。CSS1Compat:標(biāo)準(zhǔn)兼容模式開(kāi)啟。
IE對(duì)盒模型的渲染在 Standards Mode和Quirks Mode是有很大差別的,在Standards Mode下對(duì)于盒模型的解釋和其他的標(biāo)準(zhǔn)瀏覽器是一樣,但在Quirks Mode模式下則有很大差別,而在不聲明Doctype的情況下,IE默認(rèn)又是Quirks Mode。
舉個(gè)例子說(shuō)明兩種模式之間的差別有多大。
當(dāng)document.compatMode等于"BackCompat"時(shí),瀏覽器客戶區(qū)寬度是document.body.clientWidth;
當(dāng)document.compatMode等于CSS1Compat時(shí),瀏覽器客戶區(qū)寬度是document.documentElement.clientWidth。
還有其他屬性類(lèi)似。這里不說(shuō)了,但是我們可以預(yù)見(jiàn)兩種模式導(dǎo)致IE渲染的基石都更改了,可想而知構(gòu)建出來(lái)的建筑物差別當(dāng)有多大。
所以請(qǐng)為每一個(gè)頁(yè)面聲明Doctype不僅僅是一個(gè)好習(xí)慣,而且是一個(gè)必要的處理。Quirks Mode可以進(jìn)垃圾堆了。
好了下面附上完整的代碼,有一個(gè)小例子(沒(méi)有后臺(tái)刷數(shù)據(jù),只是顯示等待條)
<!DOCTYPE html> <html lang="ch-cn"> <head> <meta charset="utf-8"> <script type="text/javascript" src='jquery-1.9.1.js'></script> <style type="text/css"> html,body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, code, form, fieldset, legend, input, button, textarea, p, blockquote, th, td{ margin: 0; padding:0; } *{ -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; } .waterfllow-loading{ z-index: 2000; display:none; } .waterfllow-loading.active{ display:block; } .waterfllow-loading img.loading-progress{ position: fixed; /*設(shè)置等待條水平居于窗口正中*/ margin-left: auto; margin-right: auto; left: 0; right: 0; /*不能設(shè)置margin-top:auto和margin-bottom:auto否則IE下bottom就不頂用了*/ bottom: 30px; } </style> </head> <body style="background:#ff0;height:1000px;"> <div class="waterfllow-loading"> <img class="loading-progress" src="busy.gif"> </div> </body> <script type="text/javascript"> //獲取頁(yè)面頂部被卷起來(lái)的高度 function scrollTop(){ return Math.max( //chrome document.body.scrollTop, //firefox/IE document.documentElement.scrollTop); } //獲取頁(yè)面文檔的總高度 function documentHeight(){ //現(xiàn)代瀏覽器(IE9+和其他瀏覽器)和IE8的document.body.scrollHeight和document.documentElement.scrollHeight都可以 return Math.max(document.body.scrollHeight,document.documentElement.scrollHeight); } //獲取頁(yè)面瀏覽器視口的高度 function windowHeight(){ //document.compatMode有兩個(gè)取值。BackCompat:標(biāo)準(zhǔn)兼容模式關(guān)閉。CSS1Compat:標(biāo)準(zhǔn)兼容模式開(kāi)啟。 return (document.compatMode == "CSS1Compat")? document.documentElement.clientHeight: document.body.clientHeight; } </script> <script type="text/javascript"> //圖片查詢中正對(duì)瀏覽器主頁(yè)面滾動(dòng)事件處理(瀑布流)。只能使用window方式綁定,使用document方式不起作用 $(window).on('scroll',function(){ if(scrollTop() + windowHeight() >= (documentHeight() - 50/*滾動(dòng)響應(yīng)區(qū)域高度取50px*/)){ waterallowData(); } }); function waterallowData(){ $('.waterfllow-loading').addClass('active'); /*$.ajax({ url:url, type:"post", data: params, success:function(data,textStatus,jQXHR){ //添加數(shù)據(jù) ... //隱藏加載條 $('.waterfllow-loading.active').removeClass('active'); } });*/ } </script> </html>
里面的加載條圖片為
以上就是滾動(dòng)條滾動(dòng)到頁(yè)面底部繼續(xù)加載的處理實(shí)例,希望對(duì)大家的學(xué)習(xí)有所幫助。
- JS實(shí)現(xiàn)判斷滾動(dòng)條滾到頁(yè)面底部并執(zhí)行事件的方法
- js監(jiān)聽(tīng)html頁(yè)面的上下滾動(dòng)事件方法
- js,jquery滾動(dòng)/跳轉(zhuǎn)頁(yè)面到指定位置的實(shí)現(xiàn)思路
- 當(dāng)滾動(dòng)條滾動(dòng)到頁(yè)面底部自動(dòng)加載增加內(nèi)容的js代碼
- js判斷滾動(dòng)條是否已到頁(yè)面最底部或頂部實(shí)例
- JS和JQUERY獲取頁(yè)面大小,滾動(dòng)條位置,元素位置(示例代碼)
- js阻止移動(dòng)端頁(yè)面滾動(dòng)的兩種方法
- JS實(shí)現(xiàn)的頁(yè)面自定義滾動(dòng)條效果
- js實(shí)現(xiàn)刷新頁(yè)面后回到記錄時(shí)滾動(dòng)條的位置【兩種方案可選】
- JavaScript實(shí)現(xiàn)頁(yè)面無(wú)縫滾動(dòng)效果
相關(guān)文章
JS實(shí)現(xiàn)超過(guò)長(zhǎng)度限制后自動(dòng)跳轉(zhuǎn)下一款文本框的方法
這篇文章主要介紹了JS實(shí)現(xiàn)超過(guò)長(zhǎng)度限制后自動(dòng)跳轉(zhuǎn)下一款文本框的方法,涉及javascript操作字符及本文框的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-02-02微信小程序用戶授權(quán)獲取手機(jī)號(hào)(getPhoneNumber)
這篇文章主要給大家介紹了關(guān)于微信小程序用戶授權(quán)獲取手機(jī)號(hào)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03JS實(shí)現(xiàn)快速的導(dǎo)航下拉菜單動(dòng)畫(huà)效果附源碼下載
本文給大家分享一個(gè)帶有變形動(dòng)畫(huà)特效的下拉導(dǎo)航菜單特效,該導(dǎo)航菜單在菜單項(xiàng)之間切換時(shí),下拉菜單會(huì)快速的根據(jù)菜單內(nèi)容的大小來(lái)動(dòng)態(tài)變形,顯示合適的下拉菜單大小,效果非常棒。對(duì)導(dǎo)航下拉菜單代碼感興趣的朋友可以參考下本文2016-11-11頁(yè)面縮放兼容性處理方法(zoom,Firefox火狐瀏覽器)
下面小編就為大家?guī)?lái)一篇頁(yè)面縮放兼容性處理方法(zoom,Firefox火狐瀏覽器)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-08-08純js實(shí)現(xiàn)重發(fā)驗(yàn)證碼按鈕倒數(shù)功能
這篇文章主要介紹了純js實(shí)現(xiàn)重發(fā)驗(yàn)證碼按鈕倒數(shù)功能,本文整理了兩個(gè)實(shí)現(xiàn)代碼,需要的朋友可以參考下2015-04-04JS雙向鏈表實(shí)現(xiàn)與使用方法示例(增加一個(gè)previous屬性實(shí)現(xiàn))
這篇文章主要介紹了JS雙向鏈表實(shí)現(xiàn)與使用方法,在之前鏈表的基礎(chǔ)上增加一個(gè)previous屬性實(shí)現(xiàn)的雙向鏈表功能,需要的朋友可以參考下2019-01-01僅IE9/10同時(shí)支持script元素的onload和onreadystatechange事件分析
測(cè)試結(jié)果可以看出,IE9后已經(jīng)開(kāi)始支持script的onload事件了。一直以來(lái)我們判斷js文件是否已經(jīng)加載完成就是用以上的兩個(gè)事件。2011-04-04