js ビジュアルエリアの読み込み: getBoundingClientRect メソッド

php是最好的语言
リリース: 2018-08-10 16:56:16
オリジナル
3395 人が閲覧しました

要素が表示領域にあるときに要素を読み込みます。たとえば、淘宝網や天猫で Web ページを開くと、すべての写真が読み込まれるわけではありませんが、スクロール バーがその領域までスクロールすると、写真が読み込まれます。

メソッド: 要素の上部からブラウザウィンドウの上部までの距離が視覚領域の高さより小さいかどうかを判断し、高さより小さい場合は表示します。ここでメソッド getBoundingClientRect() を使用できます。このメソッドは、要素の 4 つの端からブラウザ ウィンドウの上部および左端までの距離を格納するオブジェクトを返します。

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 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート