JS鼠標(biāo)滾動(dòng)分頁效果示例
首先先看問題:
在開發(fā)的時(shí)候,看到這種現(xiàn)象 就會(huì)思考:為什么左邊的數(shù)據(jù)出來比右邊的慢呢?因?yàn)檫@里沒有進(jìn)行分頁,左邊的數(shù)據(jù)多,所以查詢相對較慢。
解決辦法就是進(jìn)行分頁,但是在項(xiàng)目中用到的插件,不能控制樣式,改變分頁的寬度,樣式就會(huì)亂掉。最簡單的辦法就是不分頁(^_^)
但是既然是自己份內(nèi)的事,為啥不做好呢?那就寫分頁唄,滾動(dòng)分頁!
問了其他同事,其他同事也。。。你去百度去。。。。
是啊,網(wǎng)上一大堆 ,但都是亂七八糟的,也沒有效果圖。。???/p>
經(jīng)過一番思考,和百度 思路來了:
需要了解三個(gè)dom元素,分別是:clientHeight、offsetHeight、scrollTop。
clientHeight:這個(gè)元素的高度,占用整個(gè)空間的高度,所以,如果一個(gè)div有滾動(dòng)條,那個(gè)這個(gè)高度則是不包括滾動(dòng)條沒顯示出來的下面部分的內(nèi)容。而只是單純的DIV的高度。
offsetHeight:是指元素內(nèi)容的高度。依照上面的,那這個(gè)高度呢就是DIV內(nèi)部的高度,包括可見部分及以滾動(dòng)條下面的不可見部分。
scrollTop:這個(gè)是什么呢?他可以理解為滾動(dòng)條可以滾動(dòng)的長度。
舉例,如果一個(gè)DIV高度是400px(即clientHeight為400),而里面的內(nèi)容是一個(gè)很長的列表,內(nèi)容的高度是1000px(即offsetHeight為1000)。那么,可見部分我們看到400px,1000px的內(nèi)容中還有600px不可見。而這不可見的部分呢,正是我們通過拉動(dòng)滾動(dòng)條才能把這一部分顯示出來。你如果滾動(dòng)條不拉動(dòng),此時(shí)scrollTop為0,如果你把滾動(dòng)條拉到底,顯示出列表最下面的部分,此時(shí),scrollTop為600?!∷詓crollTop的取值區(qū)間為[0, 600]?!∷赃@個(gè)600可以理解為滾動(dòng)條可以滾動(dòng)的長度。
理解完上面的這個(gè)概念之后。要判斷是否滾動(dòng)到底部就很好做了。
首先,我們拉動(dòng)滾動(dòng)條,從最上面拉到最下面,變化的是scrollTop的值,而這個(gè)值是有一個(gè)區(qū)間的。
這個(gè)區(qū)間是: [0, (offsetHeight - clientHeight)]
這里說的已經(jīng)很明白了,然后我再補(bǔ)充幾點(diǎn):
這個(gè)scrollTop 是離滾動(dòng)窗口的頂部的距離,還有就是要計(jì)算這個(gè)滾動(dòng)條離底部的距離 ,要不然滾動(dòng)事件會(huì)多次觸發(fā),還會(huì)出現(xiàn)往上滾動(dòng)觸發(fā)。
相關(guān)實(shí)現(xiàn)代碼:
//滾動(dòng)進(jìn)行分頁 $(".table-scrollable").scroll(function(){ //獲得滾動(dòng)的高度 var scrollhight = $(".page-risk-sumary .table-scrollable").scrollTop(); //獲得滾動(dòng)窗口的高度 var windowScrollhight = $(".page-risk-sumary .table-scrollable").height(); //獲得文檔高度 var domhight = $(".page-risk-sumary .table-scrollable").get(0).scrollHeight; if(scrollhight-17>=domhight-windowScrollhight){ pageNumber = (Number(pageNumber)+1)+""; if(pageNumber<=showContent.totalPage){ showContent.getContractList({ "pageNumber":pageNumber, "pageSize": "10", "focus":"0" }); } } });
這個(gè)17 是通過 domhight-windowScrollhight得到的,這個(gè)也就是滾動(dòng)條到底部的距離。
很容易吧,這樣就實(shí)現(xiàn)滾動(dòng)分頁了?。?!
看下效果圖:
以上所述是小編給大家介紹的JS鼠標(biāo)滾動(dòng)分頁效果示例,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
禁用Enter鍵表單自動(dòng)提交實(shí)現(xiàn)代碼
這篇文章主要介紹了禁用Enter鍵表單自動(dòng)提交實(shí)現(xiàn)代碼,需要的朋友可以參考下2014-05-05JS簡單去除數(shù)組中重復(fù)項(xiàng)的方法
這篇文章主要介紹了JS簡單去除數(shù)組中重復(fù)項(xiàng)的方法,涉及javascript針對數(shù)組的遍歷、判斷與運(yùn)算相關(guān)操作技巧,需要的朋友可以參考下2016-09-09javascript中BOM基礎(chǔ)知識(shí)總結(jié)
本文主要對javascript中BOM基礎(chǔ)知識(shí)進(jìn)行總結(jié)。具有很好的參考價(jià)值,下面跟著小編一起來看下吧2017-02-02JavaScript中實(shí)現(xiàn)頁面跳轉(zhuǎn)的幾種常用方法總結(jié)
本文主要介紹了網(wǎng)頁開發(fā)中頁面跳轉(zhuǎn)的概念和重要性,及使用JS實(shí)現(xiàn)頁面跳轉(zhuǎn)的幾種常見方法,包括使用window.location.href,window.location.replace(),window.location.assign(),window.open(),form表單提交以及HTML的a標(biāo)簽等方法實(shí)現(xiàn)頁面跳轉(zhuǎn),需要的朋友可以參考下2024-10-10JS實(shí)現(xiàn)圖片高斯模糊切換效果的焦點(diǎn)圖實(shí)例
這篇文章主要給大家介紹了利用原生JS如何實(shí)現(xiàn)圖片高斯模糊切換效果的焦點(diǎn)圖,文中給出了完整的實(shí)例代碼,相信對大家的理解和學(xué)習(xí)具有一定的參考借鑒價(jià)值,下面來一起看看吧。2017-01-01javascript通過navigator.userAgent識(shí)別各種瀏覽器
識(shí)別各種瀏覽器的實(shí)現(xiàn)原理是根據(jù)navigator.userAgent返回值識(shí)別,下面有個(gè)不錯(cuò)的示例,感興趣的朋友可以參考下2013-10-10mysql輸出數(shù)據(jù)賦給js變量報(bào)unterminated string literal錯(cuò)誤原因
mysql 數(shù)據(jù)庫數(shù)據(jù)賦給js變量報(bào)unterminated string literal錯(cuò)誤原因2010-05-05原生js實(shí)現(xiàn)電商側(cè)邊導(dǎo)航效果
本文主要分享了原生js實(shí)現(xiàn)電商側(cè)邊導(dǎo)航效果的示例代碼以及原理分析。具有很好的參考價(jià)值,下面跟著小編一起來看下吧2017-01-01js 實(shí)現(xiàn)無干擾陰影效果 簡單好用(附文件下載)
js實(shí)現(xiàn)無干擾陰影效果,簡單好用,需要的朋友可以參考下。2009-12-12js控制文本框只能輸入中文、英文、數(shù)字與指定特殊符號的實(shí)現(xiàn)代碼
下面小編就為大家?guī)硪黄猨s控制文本框只能輸入中文、英文、數(shù)字與指定特殊符號的實(shí)現(xiàn)代碼。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-09-09