JS scroll系列簡明教程

本文自出“阿敏其人”技術(shù)博客,轉(zhuǎn)載請取得本人同意。

文:阿敏其人


一大脉、scroll團隊成員

scroll,滾動水孩,一般討論的是網(wǎng)頁整體與瀏覽器之間的關(guān)系镰矿。

瀏覽器的的寬高是固定的,但是頁面的一般高度都遠遠大于瀏覽器的高度俘种,有時候?qū)挾纫矔笥跒g覽器的寬度秤标。

Js中有一些系列的方法scroll的方法和屬性。

打開經(jīng)典的W3c宙刘,看一下Dom Element對象關(guān)于scroll的屬性苍姜。

屬性/方法 解釋
element.scrollHeight 返回元素的整體高度。
element.scrollWidth 返回元素的整體寬度悬包。
element.scrollLeft 返回元素左邊緣與視圖之間的距離衙猪。
element.scrollTop 返回元素上邊緣與視圖之間的距離。

這四個屬性布近,全部是只讀屬性垫释。

其中,無非就是分為寬高左上撑瞧。
兩個方向棵譬。

image.png

準備工作

想要研究頁面滾動時,頁面和瀏覽器的之間的關(guān)系预伺,那么首先订咸,我們應該擁有一個頁面滾動的監(jiān)聽方法

偽代碼

監(jiān)聽方法{
    // scrollHeight
    // scrollTop
}

方向是沒錯的酬诀,但是過程是曲折的脏嚷。

最簡單的 監(jiān)聽方法
window.onscroll = function() { 頁面滾動語句 }

但是,這樣是不行的料滥,有兼容性問題然眼。,在不同的瀏覽器下會有不同的監(jiān)聽方法葵腹,所以我們應該先準備一個通用的方法高每,做好兼容工作屿岂。(萬惡的碎片化!>洹爷怀!)

具體的差異

  • 谷歌瀏覽器 和沒有聲明 DTD :
    document.body.scrollTop;
  • 火狐 和其他瀏覽器
    document.documentElement.scrollTop;
  • ie9+ 和 最新瀏覽器 都認識
    window.pageXOffset; pageYOffset (scrollTop)

==兼容的封裝方法==

兼容不同瀏覽器,返回Json格式的寬和高

<script>
    // var json = {left: 10, right: 10} 變異
    //json.left json.top
    function scroll() {
        if(window.pageYOffset != null) // ie9+ 和其他瀏覽器
        {
            return {
                left: window.pageXOffset,
                top: window.pageYOffset
            }
        }
        else if(document.compatMode == "CSS1Compat") // 聲明的了 DTD
          // 檢測是不是怪異模式的瀏覽器 -- 就是沒有 聲明<!DOCTYPE html>
        {
            return {
                left: document.documentElement.scrollLeft,
                top: document.documentElement.scrollTop
            }
        }
        return { // 剩下的肯定是怪異模式的
            left: document.body.scrollLeft,
            top: document.body.scrollTop
        }
    }
    window.onscroll = function() {
        console.log(scroll().top);
    }
</script>

二带欢、scrollLeft 和 scrollTop

獲取scrollLeft 和 scrollTop运授。

根據(jù)封裝好的方法,我們在頁面上放置了一個 100*100 px的盒子乔煞。
進行一下滾動吁朦,基于可以在控制臺看到很多即時打印的數(shù)據(jù)。

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <style>
        body {
            height: 3000px;
            margin: 0px;
            padding: 0px;
        }

        #div0{
            width: 100px;
            height: 100px;
            background: red;
        }

    </style>
</head>
<body>
<div id="div0"></div>
</body>
</html>
<script>
    // var json = {left: 10, right: 10} 變異
    //json.left json.top
    function scroll() {
        if(window.pageYOffset != null) // ie9+ 和其他瀏覽器
        {
            return {
                left: window.pageXOffset,
                top: window.pageYOffset
            }
        }
        else if(document.compatMode == "CSS1Compat") // 聲明的了 DTD
        // 檢測是不是怪異模式的瀏覽器 -- 就是沒有 聲明<!DOCTYPE html>
        {
            return {
                left: document.documentElement.scrollLeft,
                top: document.documentElement.scrollTop
            }
        }
        return { // 剩下的肯定是怪異模式的
            left: document.body.scrollLeft,
            top: document.body.scrollTop
        }
    }
    window.onscroll = function() {
        console.log("top: "+scroll().top);
        console.log("left: "+scroll().left);
    }
</script>

.
.
效果

image.png

.
.

小結(jié)圖

image.png

.
.

三渡贾、 scrollHeight 和 scrollWidth

scrollHeight和scrollWidth類似逗宜,我們以scrollHeight為例子。

  • 使用scrollHeight和scrollWidth屬性返回元素的高度空骚,單位為px,包括padding
  • scrollHeight 和 scrollWidth返回的數(shù)值是包括當前不可見部分的纺讲。
  • scrollHeight 和 scrollWidth 屬性為只讀屬性

栗子

<!DOCTYPE html>

<html>

<head>

    <meta charset="UTF-8">

    <style>

        #myD {
            margin-top: 10px;
            height: 200px;
            width: 250px;
            /*內(nèi)容溢出設置*/
            overflow: auto;
        }
        /*一個內(nèi)容高度遠比容器高度的例子*/
        #content {
            height: 500px;
            width: 1000px;
            padding: 10px;
            background-color: lightblue;
        }
    </style>
</head>

<body>
<p>點擊以下按鈕,獲取id="content"的div元素的寬度和高度</p>
<button onclick="myFc()">按鈕</button>
<div id="myD">
    <div id="content">內(nèi)容</div>
</div>
<p id="demo"></p>

<script>
    function myFc() {
        var elmnt = document.getElementById("content");
        var y = elmnt.scrollHeight;
        var x = elmnt.scrollWidth;
        document.getElementById("demo").innerHTML = "高度: " + y + "px<br>寬度: " + x + "px";
    }

</script>
</body>
</html>

.
.

結(jié)果:


image.png

小結(jié)圖

image.png

上面介紹的四個屬性囤屹,是從屬于元素的熬甚。

.
.


Element對象關(guān)于scroll的屬性 小結(jié)圖

image.png

.
.

window對象的scrollBy() 和scrollTo()

scrollBy()和scrollTo()方法是從屬于window對象的。

scrollBy(x,y)

scrollBy(x,y)方法滾動當前window中顯示的文檔肋坚,x和y指定滾動的相對量乡括。

scrollBy(0, 200) ==> 使得滾動條Y軸的位置,在當前的基礎上增加200冲簿。比如:當前Y軸位置為0粟判,執(zhí)行后便是200;當前為100峦剔,執(zhí)行后便是300。

  • 要使此方法工作 window 滾動條的可見屬性必須設置為true角钩!
<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>test</title>
    <script>
        function scrollWindow(){
            //x軸方向的的變化用得少
            window.scrollBy(100,100);
        }
    </script>
</head>
<body>

<input type="button" onclick="scrollWindow()" value="滾動條" />

<div style="width: 200px; height: 500px; background: darkcyan;font-size: 50px">001</div>
<div style="width: 200px; height: 500px; background: orange;font-size: 50px">002</div>
<div style="width: 200px; height: 500px; background: olivedrab;font-size: 50px">003</div>
<div style="width: 200px; height: 500px; background: aqua;font-size: 50px">004</div>
<div style="width: 200px; height: 500px; background: grey;font-size: 50px">005</div>

</body>
</html>

.
.
效果

image.png

scrollTo(x,y)

語法

scrollTo(xpos,ypos)
  • xpos 必需吝沫。要在窗口文檔顯示區(qū)左上角顯示的文檔的 x 坐標。
  • ypos 必需递礼。要在窗口文檔顯示區(qū)左上角顯示的文檔的 y 坐標惨险。

作用

scrollTo(x,y)方法:滾動當前window中顯示的文檔,讓文檔中由坐標x和y指定的點位于顯示區(qū)域的左上角

scrollTo(0, 200) ==> 同scroll()方法,設置Y軸在200像素的位置脊髓。

示例

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>test</title>
    <script>
        function scrollWindow(){
            //x軸方向的的變化用得少
            window.scrollTo(0,1200);
        }
    </script>
</head>
<body>

<input type="button" onclick="scrollWindow()" value="滾動條" />

<div style="width: 200px; height: 500px; background: darkcyan;font-size: 50px">001</div>
<div style="width: 200px; height: 500px; background: orange;font-size: 50px">002</div>
<div style="width: 200px; height: 500px; background: olivedrab;font-size: 50px">003</div>
<div style="width: 200px; height: 500px; background: aqua;font-size: 50px">004</div>
<div style="width: 200px; height: 500px; background: grey;font-size: 50px">005</div>

</body>
</html>

.
.
效果:

image.png


相關(guān):

JS offset系列簡明教程
JS client系列簡明教程

本文完辫愉。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市将硝,隨后出現(xiàn)的幾起案子恭朗,更是在濱河造成了極大的恐慌屏镊,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,651評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件痰腮,死亡現(xiàn)場離奇詭異而芥,居然都是意外死亡,警方通過查閱死者的電腦和手機膀值,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,468評論 3 392
  • 文/潘曉璐 我一進店門棍丐,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人沧踏,你說我怎么就攤上這事歌逢。” “怎么了翘狱?”我有些...
    開封第一講書人閱讀 162,931評論 0 353
  • 文/不壞的土叔 我叫張陵趋翻,是天一觀的道長。 經(jīng)常有香客問我盒蟆,道長踏烙,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,218評論 1 292
  • 正文 為了忘掉前任历等,我火速辦了婚禮讨惩,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘寒屯。我一直安慰自己荐捻,他們只是感情好,可當我...
    茶點故事閱讀 67,234評論 6 388
  • 文/花漫 我一把揭開白布寡夹。 她就那樣靜靜地躺著处面,像睡著了一般。 火紅的嫁衣襯著肌膚如雪菩掏。 梳的紋絲不亂的頭發(fā)上魂角,一...
    開封第一講書人閱讀 51,198評論 1 299
  • 那天,我揣著相機與錄音智绸,去河邊找鬼野揪。 笑死,一個胖子當著我的面吹牛瞧栗,可吹牛的內(nèi)容都是我干的斯稳。 我是一名探鬼主播,決...
    沈念sama閱讀 40,084評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼迹恐,長吁一口氣:“原來是場噩夢啊……” “哼挣惰!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,926評論 0 274
  • 序言:老撾萬榮一對情侶失蹤憎茂,失蹤者是張志新(化名)和其女友劉穎珍语,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體唇辨,經(jīng)...
    沈念sama閱讀 45,341評論 1 311
  • 正文 獨居荒郊野嶺守林人離奇死亡廊酣,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,563評論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了赏枚。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片亡驰。...
    茶點故事閱讀 39,731評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖饿幅,靈堂內(nèi)的尸體忽然破棺而出凡辱,到底是詐尸還是另有隱情,我是刑警寧澤栗恩,帶...
    沈念sama閱讀 35,430評論 5 343
  • 正文 年R本政府宣布透乾,位于F島的核電站,受9級特大地震影響磕秤,放射性物質(zhì)發(fā)生泄漏乳乌。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,036評論 3 326
  • 文/蒙蒙 一市咆、第九天 我趴在偏房一處隱蔽的房頂上張望汉操。 院中可真熱鬧,春花似錦蒙兰、人聲如沸磷瘤。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,676評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽采缚。三九已至,卻和暖如春挠他,著一層夾襖步出監(jiān)牢的瞬間扳抽,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,829評論 1 269
  • 我被黑心中介騙來泰國打工绩社, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留摔蓝,地道東北人。 一個月前我還...
    沈念sama閱讀 47,743評論 2 368
  • 正文 我出身青樓愉耙,卻偏偏與公主長得像,于是被迫代替她去往敵國和親拌滋。 傳聞我的和親對象是個殘疾皇子朴沿,可洞房花燭夜當晚...
    茶點故事閱讀 44,629評論 2 354

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