scrollHeight,clientHeight,scrollTop明晰

移動端加載數(shù)據(jù)時抖僵,由于數(shù)據(jù)太多,不會一次性全部加載出來裆针。有些會采用pc端那樣用分頁碼的形式寺晌,但是更多的確實滑動滾動條到內(nèi)容最后呻征,加載更多內(nèi)容出來。一般引入了三方的前端框架和插件陆赋,基本都會有此功能嚷闭。偶爾會需要采用原生js實現(xiàn),故而此處就介紹下原生js的實現(xiàn)方式胞锰。另外附上jquery的實現(xiàn)方式。

原生js實現(xiàn)思路

需要三個高度:
scrollHeight(文檔內(nèi)容實際高度顺饮,包括超出視窗的溢出部分)、
scrollTop(滾動條滾動距離)兼雄、
clientHeight(窗口可視范圍高度)帽蝶。

clientHeight + scrollTop >= scrollHeight 時,表示已經(jīng)抵達內(nèi)容的底部了励稳,可以加載更多內(nèi)容。

  • scrollHeight:可以通過 document.documentElement.scrollHeight 驹尼、document.body.scrollHeight 獲取;
  • clientHeight:可以通過window.innerHeightdocument.documentElement.clientHeight 獲取;
  • scrollTop:可以通過window.pageYOffsetdocument.documentElement.scrollTop 獲取;

下面附上三者之間的關系:


image.png
測試代碼:
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>scroll</title>
    <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
    <style>
    * {
        margin: 0;
        padding: 0;
    }
    .scroll{
        margin-top: 0px;
        border: 2px solid #00f;
        height: 2000px;
    }
    #js_con {
        position: fixed;
        top: 50px;
    }
</style>
</head>
<body>
    <div class="scroll">
        <div id="js_con"></div>
    </div>
</body>
<script>
    window.onscroll = function() {
        var str = ``;
        str += `scrollHeight:(${document.documentElement.scrollHeight}, ${document.body.scrollHeight})<br />`;
        str += `clientHeight/innerHeight:(${document.documentElement.clientHeight}, ${window.innerHeight})<br />`;
        str += `scrollTop/pageYOffset:(${document.documentElement.scrollTop}, ${window.pageYOffset})`;
        document.getElementById('js_con').innerHTML = str;
        console.log(str);
    }
</script>
</html>
jquery實現(xiàn)方式:
<script>
    $(window).on("resize scroll",function() {
        var windowHeight = $(window).height();//當前窗口的高度             
        var scrollTop = $(window).scrollTop();//當前滾動條從上往下滾動的距離            
        var docHeight = $(document).height(); //當前文檔的高度 
        console.log(scrollTop, windowHeight, docHeight);
        // 觸底公式:(滾動條滾動的高度 + 可視窗口的高度 = 文檔的高度)  這個是基本的公式  
        if (scrollTop + windowHeight >= docHeight) { 
            console.log("===加載更多數(shù)據(jù)===");
        }
    });
</script>

JQuery 獲取三個高度 和 原生獲取三個高度的方式:

$(document).height();  ==  document.documentElement.scrollHeight;    // 文檔內(nèi)容的實際高度
$(window).scrollTop(); == document.documentElement.scrollTop;        // 滾動條滾動高度
$(window).height(); == document.documentElement.clientHeight;        // 可視窗口高度
最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市澎羞,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌妆绞,老刑警劉巖顺呕,帶你破解...
    沈念sama閱讀 217,406評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異来涨,居然都是意外死亡,警方通過查閱死者的電腦和手機蹦掐,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評論 3 393
  • 文/潘曉璐 我一進店門僵闯,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人社裆,你說我怎么就攤上這事∮拘悖” “怎么了?”我有些...
    開封第一講書人閱讀 163,711評論 0 353
  • 文/不壞的土叔 我叫張陵晶默,是天一觀的道長航攒。 經(jīng)常有香客問我,道長漠畜,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,380評論 1 293
  • 正文 為了忘掉前任蝴悉,我火速辦了婚禮瘾敢,結果婚禮上,老公的妹妹穿的比我還像新娘簇抵。我一直安慰自己,他們只是感情好碟摆,可當我...
    茶點故事閱讀 67,432評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著断盛,像睡著了一般罗洗。 火紅的嫁衣襯著肌膚如雪伙菜。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,301評論 1 301
  • 那天仇让,我揣著相機與錄音躺翻,去河邊找鬼。 笑死公你,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的陕靠。 我是一名探鬼主播,決...
    沈念sama閱讀 40,145評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼垄开,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了溉躲?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,008評論 0 276
  • 序言:老撾萬榮一對情侶失蹤锻梳,失蹤者是張志新(化名)和其女友劉穎净捅,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體蛔六,經(jīng)...
    沈念sama閱讀 45,443評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,649評論 3 334
  • 正文 我和宋清朗相戀三年屁魏,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片你画。...
    茶點故事閱讀 39,795評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡桃漾,死狀恐怖拟逮,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情敦迄,我是刑警寧澤,帶...
    沈念sama閱讀 35,501評論 5 345
  • 正文 年R本政府宣布苦囱,位于F島的核電站,受9級特大地震影響撕彤,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜羹铅,卻給世界環(huán)境...
    茶點故事閱讀 41,119評論 3 328
  • 文/蒙蒙 一愉昆、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧跛溉,春花似錦、人聲如沸倒谷。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至抖格,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間雹拄,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評論 1 269
  • 我被黑心中介騙來泰國打工坪哄, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 47,899評論 2 370
  • 正文 我出身青樓模暗,卻偏偏與公主長得像念祭,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子粱坤,可洞房花燭夜當晚...
    茶點故事閱讀 44,724評論 2 354

推薦閱讀更多精彩內(nèi)容

  • 移動端加載數(shù)據(jù)時,由于數(shù)據(jù)太多枚驻,不會一次性全部加載出來蜒什。有些會采用pc端那樣用分頁碼的形式,但是更多的確實滑動滾動...
    恬雅過客閱讀 18,443評論 0 14
  • 今天玩 antd-mobile 碰到一個滾動條的問題:在 Tab 組件中使用多個 ListView 霎冯,當操作第一個...
    BertFu閱讀 30,513評論 7 9
  • 個人博客:https://yeaseonzhang.github.io 花了半個多月的時間钞瀑,終于又把“JS紅寶書”...
    Yeaseon閱讀 11,524評論 9 52
  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML標準雕什。 注意:講述HT...
    kismetajun閱讀 27,485評論 1 45
  • 100個常用的javascript函數(shù) 1、原生JavaScript實現(xiàn)字符串長度截取 復制代碼代碼如下: fun...
    老頭子_d0ec閱讀 356評論 0 0