要素が表示領域にあるときに要素を読み込みます。たとえば、淘宝網や天猫で Web ページを開くと、すべての写真が読み込まれるわけではありませんが、スクロール バーがその領域までスクロールすると、写真が読み込まれます。
メソッド: 要素の上部からブラウザウィンドウの上部までの距離が視覚領域の高さより小さいかどうかを判断し、高さより小さい場合は表示します。ここでメソッド getBoundingClientRect() を使用できます。このメソッドは、要素の 4 つの端からブラウザ ウィンドウの上部および左端までの距離を格納するオブジェクトを返します。
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 ビジュアルエリアの読み込み: getBoundingClientRect メソッドの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。