首頁 > web前端 > js教程 > 主體

js可視區域載入:getBoundingClientRect方法

php是最好的语言
發布: 2018-08-10 16:56:16
原創
3404 人瀏覽過

       當元素處於可視區域時再加載,例如淘寶天貓上打開網頁時不是所有圖片都加載出來了,而是當滾動條滾動到那個區域時才加載出來圖片。

方法:判斷元素頂部到瀏覽器視窗頂部的距離是否小於視覺區域高度,如果小於就顯示。這裡可以用一個方法: getBoundingClientRect(),該方法傳回一個對象,該物件儲存了元素四個邊界到瀏覽器視窗上邊和左邊的距離。

getBoundingClientRect方法:

js可視區域載入:getBoundingClientRect方法

#
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>可视区域加载</title>
    <style>
        #showp {
            width: 500px;
            height: 350px;
            background-color: aqua;
            margin: 1000px auto 0 auto;
        }
        
        .showp {
            animation: loading 2s linear;
        }
        
        @keyframes loading {
            from {
                opacity: 0;
                transform: translate(-100%, 0);
            }
            to {
                opacity: 1;
                transform: translate(0, 0);
            }
        }
    </style>
</head>

<body>
    <p id="showp"></p>
    <script type="text/javascript">
        window.onscroll = function() {
            var show = document.getElementById("showp");
            // 获取浏览器窗口可视化高度
            var clientH = window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight;
            // 获取showp元素顶部到浏览器窗口顶部的距离
            var showTop = show.getBoundingClientRect().top;
            // 如果距离小于可视化窗口高度,就给showp元素添加动画效果
            if (showTop <= clientH) {
                show.classList.add("showp");
            }
        };
    </script>
</body>

</html>
登入後複製

#執行結果:不知道為什麼。 。 。結果的動圖貼不上來。 。 。 。口述一下好了:就是動畫開始不加載,滾動條滾動到可以顯示元素的時候才會開始加載動畫。可以利用這個原理來實現圖片的加載,就是圖片到可視區域的時候給它賦src的值。
相關建議:

JS圖片預先載入實例

#看大圖點擊大圖隱藏 

以上是js可視區域載入:getBoundingClientRect方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板