您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

JS实现图片懒加载教程

2024/6/22 20:49:48发布32次查看
图片懒加载,
思路:当鼠标滑动到对应图片的高度时,进行图片的加载;
<!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设置定位*/ 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 值 考虑兼容问题 var oscrolltop = document.documentelement.scrolltop || document.body.scrolltop; // clientheight = 上下padding + height var clienth = document.documentelement.clientheight; //循环遍历每一项通过调用获取到每一个i 项对象的top 值 for (var i = 0;i<aimg.length;i++) { var aimgtop = getpos(aimg[i]).top; // 当滚动的时候进行判断,看他的滚动的高度加上它的clientheight 是否比它的 top 值大 // 如果大或等于说明滚动到当前位置可以加载图片 if (oscrolltop + clienth >= aimgtop) { // 进行图片的加载 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>
当有类似于瀑布流的布局时常用的 加载模式
<script> var num = document.getelementsbytagname('img').length; var img = document.getelementsbytagname("img"); var n = 0; //存储图片加载到的位置,避免每次都从第一张图片开始遍历 lazyload(); //页面载入完毕加载可是区域内的图片 window.onscroll = lazyload; function lazyload() { //监听页面滚动事件 var seeheight = document.documentelement.clientheight; //可见区域高度 var scrolltop = document.documentelement.scrolltop || document.body.scrolltop; //滚动条距离顶部高度 for (var i = n; i < num; i++) { if (img[i].offsettop < seeheight + scrolltop) { if (img[i].getattribute("src") == "") { img[i].src = img[i].getattribute("data-src"); } n = i + 1; } } } </script>
<script> var n = 0, imgnum = $("img").length, img = $('img'); lazyload(); $(window).scroll(lazyload); function lazyload(event) { for (var i = n; i < imgnum; i++) { if (img.eq(i).offset().top < parseint($(window).height()) + parseint($(window).scrolltop())) { if (img.eq(i).attr("src") == "") { var src = img.eq(i).attr("data-src"); img.eq(i).attr("src", src); n = i + 1; } } } } </script>
以上就是js实现图片懒加载教程的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product