本文實(shí)例為大家分享了js圖片懶加載的具體代碼,供大家參考,具體內(nèi)容如下
圖片懶加載,思路:當(dāng)鼠標(biāo)滑動(dòng)到對(duì)應(yīng)圖片的高度時(shí),進(jìn)行圖片的加載;
<!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title></title> <style type="text/css"> #div{ width: 575px; height: auto; overflow: hidden; border: red 1px solid; margin: 0 auto; /*給該div設(shè)置定位*/ position: relative; } #div img{ width: 267px; height: 396px; margin-left: 10px; border: 1px solid #000; } </style> <script type="text/javascript"> function getPos(obj){ var l = 0; var t = 0; while(obj){ l += obj.offsetLeft; t += obj.offsetTop; obj = obj.offsetParent; } return {left:l ,top : t} } window.onload = window.onscroll = function(){ //獲取到img var aImg = document.getElementsByTagName("img"); //獲取到它的scrollTop 值 考慮兼容問(wèn)題 var oScrollTop = document.documentElement.scrollTop || document.body.scrollTop;// clientHeight = 上下padding + height var clientH = document.documentElement.clientHeight; //循環(huán)遍歷每一項(xiàng)通過(guò)調(diào)用獲取到每一個(gè)i 項(xiàng)對(duì)象的top 值 for (var i = 0;i<aImg.length;i++) { var aImgTop = getPos(aImg[i]).top;// 當(dāng)滾動(dòng)的時(shí)候進(jìn)行判斷,看他的滾動(dòng)的高度加上它的clientHeight 是否比它的 top 值大 // 如果大或等于說(shuō)明滾動(dòng)到當(dāng)前位置可以加載圖片 if (oScrollTop + clientH >= aImgTop) {// 進(jìn)行圖片的加載 aImg[i].src = aImg[i].getAttribute("_src"); } } } </script> </head> <body> <div id="div"> <img _src="../img/1.jpg"/> <img _src="../img/2.jpg"/> <img _src="../img/3.jpg"/> <img _src="../img/4.jpg"/> <img _src="../img/6.jpg"/> <img _src="../img/7.jpg"/> <img _src="../img/1.jpg"/> <img _src="../img/2.jpg"/> <img _src="../img/3.jpg"/> <img _src="../img/4.jpg"/> <img _src="../img/6.jpg"/> <img _src="../img/7.jpg"/> <img _src="../img/3.jpg"/> <img _src="../img/4.jpg"/> <img _src="../img/6.jpg"/> <img _src="../img/7.jpg"/> </div> </body></html>當(dāng)有類似于瀑布流的布局時(shí)常用的加載模式
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持VeVb武林網(wǎng)。
新聞熱點(diǎn)
疑難解答