
etc
DOMRect对象中的width和height是包含了元素的padding和border-width,其位置信息指的是包含元素的最小矩形的每条边距离视窗原点(0,0)的位置。throttle由于我们会全局监听scroll滚动事件,如果每次滚动都触发回调函数的话会造成不必要的计算成本,因此我们考虑使用节流来处理滚动事件。节流的具体细节就不在此重复,我们先简单实现一个节流:functionthrottle(fn,delay=200){lettimer=null;returnfunction(){if(timer)return;timer=setTimeout(()={fn.apply(this,arguments);timer=null;},delay);}}window.innerHeight有几个很相似的”height“,我们就简单都梳理一下:window.innerHeight:浏览器可视区域的高度;如果有水平滚动条,也会包含滚动条高度window.outerHeight:获取整个浏览器的高度Element.scrollHeight:元素内容的高度,包括由于溢出导致隐藏的内容高度Element.clientHeight:元素内部的高度,包含内边距,但不包括水平滚动条、边框、外边距这里我们使用innerHeight即可,因为我们是在window对象上监听scroll滚动事件。准备工作已经完毕,接下来就直接上手代码。完整代码代码中都有相应的注释,在了解上面的准备知识后,代码就挺简单的了:JS部分//使用for循环批量创建img,html中可没有v-for可以使用for(letindex=0;index10;index++){letimg=document.createElement(img);img.src=./loading.gif;img.dataset.src=./dog.jfif;//由于我们是通过JS创建的,因此就无法直接使用data-*,如果是在html上面,需要添加此属性document.body.appendChild(img);img=null;}//节流functionthrottle(fn,delay=200){lettimer=null;returnfunction(){if(timer)return;timer=setTimeout(()={fn.apply(this,arguments);timer=null;},delay);};}//懒加载-回调函数functionlazyLoad(){constimgs=document.querySelectorAll('img[data-src]');if(!imgs.length)return;imgs.forEach(img={constrect=img.getBoundingClientRect();if(rect.topwindow.innerHeight){img.src=img.dataset.src;img.removeAttribute('data-src');//我们是通过img[data-src]查找所有img标签的,渲染后就删除data-src可减少forEach循环的计算成本}})}//全局监听scroll滚动事件window.addEventListener('scroll',throttle(()={lazyLoad();},100));//初始化的时候执行一下加载图片的函数lazyLoad();CSS部分stylebody{display:flex;flex-direction:column;align-items:center;}img{margin:10pxauto;width:600px;height:400px;object-fit:cover;border-radius:4px;border:1pxsolid#070707;}/style运行结果:首屏展示:
首先我们会默认加载三张图片,查看元素节点,这三张图片的data-src都没有,而另外没有加载的图片是有data-src的。滚动中展示:

JS
所有图片都将只有src,没有data-src。总结本文通过监听滚动事件,在图片出现在可视区域前才加载真正的图片,如果未出现则使用默认的loading图片的方式实现了图片懒加载。一般来说,loading图片都会比较小,而实际的图片会大很,因此使用loading图片来代替是可以减少图片渲染时间的。原文:https://juejin.cn/post/7111609083441971208
Copyright © 2025 IZhiDa.com All Rights Reserved.
知答 版权所有 粤ICP备2023042255号