JS鼠標(biāo)滾動(dòng)分頁效果示例
首先先看問題:

在開發(fā)的時(shí)候,看到這種現(xiàn)象 就會(huì)思考:為什么左邊的數(shù)據(jù)出來比右邊的慢呢?因?yàn)檫@里沒有進(jìn)行分頁,左邊的數(shù)據(jù)多,所以查詢相對(duì)較慢。
解決辦法就是進(jìn)行分頁,但是在項(xiàng)目中用到的插件,不能控制樣式,改變分頁的寬度,樣式就會(huì)亂掉。最簡(jiǎn)單的辦法就是不分頁(^_^)
但是既然是自己份內(nèi)的事,為啥不做好呢?那就寫分頁唄,滾動(dòng)分頁!
問了其他同事,其他同事也。。。你去百度去。。。。
是啊,網(wǎng)上一大堆 ,但都是亂七八糟的,也沒有效果圖。。。坑
經(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)的長(zhǎng)度。
舉例,如果一個(gè)DIV高度是400px(即clientHeight為400),而里面的內(nèi)容是一個(gè)很長(zhǎng)的列表,內(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。 所以scrollTop的取值區(qū)間為[0, 600]?!∷赃@個(gè)600可以理解為滾動(dòng)條可以滾動(dòng)的長(zhǎ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)分頁效果示例,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
js style動(dòng)態(tài)設(shè)置table高度
設(shè)置table高度想必大家都會(huì),直接在table標(biāo)簽中設(shè)置下不就行了嗎?這是靜態(tài)的,如果要?jiǎng)討B(tài)設(shè)置你會(huì)嗎?下面的實(shí)例將教會(huì)大家2014-10-10
JavaScript如何實(shí)現(xiàn)圖片懶加載(lazyload) 提高用戶體驗(yàn)(增強(qiáng)版)
這篇文章主要介紹了JavaScript如何實(shí)現(xiàn)圖片懶加載(lazyload) 提高用戶體驗(yàn)(增強(qiáng)版)的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-11-11
jsonp格式前端發(fā)送和后臺(tái)接受寫法的代碼詳解
jsonp是ajax提交的一種格式不會(huì)受跨域限制,這篇文章主要介紹了jsonp格式前端發(fā)送和后臺(tái)接受寫法的代碼詳解,需要的朋友可以參考下2019-11-11
jQuery中 DOM節(jié)點(diǎn)操作方法大全
本文給大家介紹了jQuery中 DOM節(jié)點(diǎn)操作方法大全,感興趣的朋友一起看看吧2017-10-10
JavaScript函數(shù)式編程(Functional Programming)純函數(shù)用法分析
這篇文章主要介紹了JavaScript函數(shù)式編程(Functional Programming)純函數(shù)用法,結(jié)合實(shí)例形式分析了javascript函數(shù)式編程中純函數(shù)的函數(shù)依賴、所指透明等概念相關(guān)原理及使用技巧,需要的朋友可以參考下2019-05-05

