首页 / JAVASCRIPT / JS实现图片懒加载教程
JS实现图片懒加载教程
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了JS实现图片懒加载教程,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2856字,纯文字阅读大概需要5分钟。
内容图文
![JS实现图片懒加载教程](/upload/InfoBanner/zyjiaocheng/300/a183dcdca40546ff879a4f47a261dfab.jpg)
思路:当鼠标滑动到对应图片的高度时,进行图片的加载;
<!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实现图片懒加载教程的详细内容,更多请关注Gxl网其它相关文章!
内容总结
以上是互联网集市为您收集整理的JS实现图片懒加载教程全部内容,希望文章能够帮你解决JS实现图片懒加载教程所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。