當元素處於可視區域時再加載,例如淘寶天貓上打開網頁時不是所有圖片都加載出來了,而是當滾動條滾動到那個區域時才加載出來圖片。
方法:判斷元素頂部到瀏覽器視窗頂部的距離是否小於視覺區域高度,如果小於就顯示。這裡可以用一個方法: getBoundingClientRect(),該方法傳回一個對象,該物件儲存了元素四個邊界到瀏覽器視窗上邊和左邊的距離。
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中文網其他相關文章!