延迟加载图像以提高模板网站建设性能的五种方法
由于图像是模板网站建设是网站建设上最流行的内容类型之一,因此网站上的页面加载时间很容易成为问题。
即使进行了适当的优化,图像也可能占很大的比重。这可能会对访问者必须等待才能访问您网站上的内容的时间产生负面影响。除非您想出一种不会干扰速度感知的图像加载解决方案,否则它们很可能会耐心地在其他地方导航。
在本文中,您将了解五种延迟加载图像的方法,可以将它们添加到Web优化工具包中以改善网站上的用户体验。
什么是延迟加载?
延迟加载图像是指异步加载网站上的图像-也就是说,在首屏内容完全加载后,甚至有条件地,仅当它们出现在浏览器的视口中时。这意味着,如果用户没有完全向下滚动,则位于页面底部的图像甚至都不会被加载。
许多网站都使用这种方法,但是在图片繁多的网站上尤其明显。尝试浏览您最喜欢的在线狩猎场以获得高分辨率照片,您很快就会意识到该网站仅加载有限数量的图像的方式。向下滚动页面时,您会看到占位符图像迅速填充真实图像进行预览。例如,请注意下图中的加载程序:将页面的该部分滚动到视图中会触发使用全分辨率照片替换占位符:
为什么要关心延迟加载图像?
至少有两个极好的原因,您应该考虑为网站延迟加载图像:
如果您的网站使用JavaScript来显示内容或向用户提供某种功能,则快速加载DOM变得至关重要。脚本通常要等到DOM完全加载后才能开始运行。在包含大量图像的网站上,延迟加载(或异步加载图像)可能会导致用户停留或离开您的网站有所不同。
由于大多数惰性加载解决方案都是通过仅在用户滚动到在视口内可见图像的位置时才加载图像来工作的,因此如果用户从未到达该点,则将永远不会加载这些图像。这意味着可以节省大量带宽,为此,大多数用户,特别是那些在移动设备上访问Web且连接缓慢的用户,将非常感谢您。
好吧,延迟加载图像有助于提高网站性能,但是最好的解决方法是什么?
没有完美的方法。
如果您生活和呼吸JavaScript,那么实现自己的延迟加载解决方案就不会成为问题。没有什么比您自己编写代码给您更多的控制权了。
或者,您可以浏览Web以找到可行的方法并开始进行试验。我就是这样做的,并且遇到了这五种有趣的技术。
#1本机延迟加载
图像和iframe的本机延迟加载非常酷。没有什么比下面的标记更直接了:
<imgsrc="myimage.jpg"loading="lazy"alt="..."/><iframesrc="content.html"loading="lazy">iframe>
如您所见,没有JavaScript,没有src
属性值的动态交换,只是普通的旧HTML。
该loading
属性使我们可以选择延迟屏幕外图像和iframe,直到用户滚动到页面上的位置为止。loading
可以采用以下三个值之一:
lazy
:非常适合延迟加载eager
:指示浏览器立即加载指定的内容auto
:保留延迟加载或不延迟加载到浏览器的选项。
这种方法无可匹敌:它的开销为零,简洁明了。但是,尽管在撰写本文时,大多数主流浏览器都对该loading
属性提供了良好的支持,但并不是所有浏览器都支持该特性。
要获得有关此令人敬畏的延迟加载图像功能的深入文章,包括浏览器支持的解决方法,请不要错过Addy Osmani的“Web的本地图像延迟加载!”。
#2使用Intersection Observer API的延迟加载
Intersection Observer API是一个现代化的界面,你可以利用的延迟加载图片和其他内容。
MDN引入此API的方法如下:
Intersection Observer API提供了一种异步观察目标元素与祖先元素或顶级文档的视口相交的变化的方法。
换句话说,异步监视的是一个元素与另一个元素的交集。
Denys Mishunov在“相交观察器”和使用它的延迟加载图像方面都有很好的教程。这就是他的解决方案。
假设您要延迟加载图片库。每个图像的标记如下所示:
<imgdata-src="image.jpg"alt="test image">
请注意,图像的路径是如何包含在data-src
属性(而不是src
属性)中的。原因是使用src
意味着图像将立即加载,这不是您想要的。
在CSS中,为每个图像赋予一个min-height
值,例如100px
。这为每个图像占位符(不带src属性的img元素)提供了一个垂直尺寸:
img{min-height:100px;/* more styles here */}
然后,在JavaScript文档中,创建一个config
对象并将其注册到intersectionObserver
实例:
// create config object: rootMargin and threshold// are two properties exposed by the interfaceconstconfig={rootMargin:0px 0px 50px 0px,threshold:0};// register the config object with an instance// of intersectionObserverletobserver=newintersectionObserver(function(entries,self){// iterate over each entryentries.forEach(entry=>{// process just the images that are intersecting.// isIntersecting is a property exposed by the interfaceif(entry.isIntersecting){// custom function that copies the path to the img// from data-src to srcpreloadImage(entry.target);// the image is now in place, stop watchingself.unobserve(entry.target);}});},config);
最后,您遍历所有图像并将它们添加到此iterationObserver
实例中:
constimgs=document.querySelectorAll([data-src]);imgs.forEach(img=>{observer.observe(img);});
该解决方案的优点:实施起来轻而易举,有效,并且intersectionObserver
在计算方面做得很繁重。
另一方面,尽管大多数浏览器都支持Intersection Observer API最新版本,但并非所有浏览器都始终支持它。幸运的是,可以使用polyfill。
您可以在Denys的文章中了解有关Intersection Observer API的更多信息以及此实现的详细信息。
#3 Lozad.js
实现图像的延迟加载的一种快速简便的替代方法是让JS库为您完成大部分工作。
Lozad是纯JavaScript中的高性能,轻量且可配置的惰性加载器,没有任何依赖关系。您可以使用它来延迟加载图像,视频,iframe和更多内容,并且它使用Intersection Observer API。
您可以将Lozad包含在npm / Yarn中,并使用所选的模块捆绑器将其导入:
npminstall--save lozadyarnaddlozad
importlozadfromlozad;
<font id="c66b10d5-af4f-4
扫一扫,关注我们