英文 | https://www.sitepoint.com/five-techniques-lazy-load-images-website-performance/翻译 | web前端开发(ID:web_qdkf)由于图像是Web上最流行也是必不可少的内容类型之一,因此网站上的图片页面加载时间很容易成为一个问题。即使进行了适当的优化,图像也可能占很大的比重。这可能会对访问网站的用户造成一定的负面影响,因为你的用户必须等待一段时间才能访问你网站上的内容。除非你想出一种不会干扰速度感知的图像加载解决方案,否则它们很可能会失去耐心,而去其他地方寻找他们所需要的内容。在本文中,你将了解5种延迟加载图像的方法,可以将它们添加到Web优化工具包中以改善网站上的用户体验。

什么是延迟加载?

延迟加载图像是指异步加载网站上的图像,也就是说,在首屏内容完全加载后,甚至有条件地,仅当它们出现在浏览器的视口中时。这意味着,如果用户没有完全向下滚动,则位于页面底部的图像甚至都不会被加载。许多网站都使用这种方法,但是在图片繁多的网站上尤其明显。尝试浏览你最喜欢的在线网站以获得高分辨率照片,你很快就会意识到该网站仅加载有限数量的图像的方式。向下滚动页面时,你会看到占位符图像迅速填充真实图像进行预览。例如,请注意Unsplash.com上的加载程序:将页面的该部分滚动到视图中会触发使用全分辨率照片替换占位符:

为什么要关心延迟加载图像?

至少有两个极好的原因,你应该考虑为网站延迟加载图像:

  • 如果你的网站使用JavaScript来显示内容或向用户提供某种功能,则快速加载DOM变得至关重要。脚本通常要等到DOM完全加载后才能开始运行。在包含大量图像的网站上,延迟加载(或异步加载图像)可能会导致用户停留或离开你的网站有所不同。

  • 由于大多数惰性加载解决方案都是通过仅在用户滚动到在视口内可见图像的位置时才加载图像来工作的,因此如果用户从未到达该点,则将永远不会加载这些图像。这意味着可以节省大量带宽,为此,大多数用户,特别是那些在移动设备上访问Web且连接缓慢的用户,将非常感谢你。

好吧,延迟加载图像有助于提高网站性能,但是最好的解决方法是什么?没有完美的方法。如果你使用JavaScript,那么实现自己的延迟加载解决方案就不会成为问题。没有什么比你自己编写代码给你更多的控制权了。或者,你可以浏览Web以找到可行的方法并开始进行试验。我就是这样做的,并且遇到了这5种有趣的技术。

1、本机延迟加载

图像和iframe的本机延迟加载非常酷。没有什么比下面的标记更直接了:如你所见,没有JavaScript,没有src属性值的动态交换,只是普通的HTML。该loading属性使我们可以选择延迟屏幕外图像和iframe,直到用户滚动到页面上的位置为止。loading可以采用以下三个值之一:

  • lazy:非常适合延迟加载

  • eager:指示浏览器立即加载指定的内容

  • auto:保留延迟加载或不延迟加载到浏览器的选项。

这种方法无可匹敌:它的开销为零,简洁明了。但是,尽管在撰写本文时,大多数主流浏览器都对该loading属性提供了良好的支持,但并不是所有浏览器都支持该特性。要获得有关此令人敬畏的延迟加载图像功能的深入文章,包括浏览器支持的解决方法,请不要错过Addy Osmani的“ Web的本地图像延迟加载!”。2、使用Intersection Observer API的延迟加载该路口观察API是一个现代化的界面,你可以利用的延迟加载图片和其他内容。MDN引入此API的方法如下:

Intersection Observer API提供了一种异步观察目标元素与祖先元素或顶级文档的视口相交的变化的方法。

换句话说,异步监视的是一个元素与另一个元素的交集。Denys Mishunov在“相交观察器”和使用它的延迟加载图像方面都有很好的教程。这就是他的解决方案。假设你要延迟加载图片库。每个图像的标记如下所示:请注意,图像的路径是如何包含在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 interfaceconst config = {  rootMargin: '0px 0px 50px 0px',  threshold: 0};// register the config object with an instance// of intersectionObserverlet observer = new intersectionObserver(function(entries, self) {  // iterate over each entry  entries.forEach(entry => {    // process just the images that are intersecting.    // isIntersecting is a property exposed by the interface    if(entry.isIntersecting) {      // custom function that copies the path to the img      // from src to src      preloadImage(entry.target);      // the image is now in place, stop watching      self.unobserve(entry.target);    }  });}, config);

最后,你遍历所有图像并将它们添加到此iterationObserver实例中:

const imgs = document.querySelectorAll('[src]');imgs.forEach(img => {  observer.observe(img);});

该解决方案的优点:实施起来轻而易举,有效,并且intersectionObserver在计算方面做得很繁重。另一方面,尽管大多数浏览器都支持Intersection Observer API最新版本,但并非所有浏览器都始终支持它。幸运的是,可以使用polyfill。

3 、Lozad.js

实现图像的延迟加载的一种快速简便的替代方法是让JS库为你完成大部分工作。Lozad是纯JavaScript中的高性能,轻量且可配置的惰性加载器,没有任何依赖关系。你可以使用它来延迟加载图像,视频,iframe和更多内容,并且它使用Intersection Observer API。你可以将Lozad包含在npm / Yarn中,并使用所选的模块捆绑器将其导入:

npm install --save lozadyarn add lozad
import lozad from 'lozad';

另外,你可以简单地使用CDN下载该库并将其添加到HTML页面底部的< script>标记中:接下来,对于基本实现,将lozad类添加到标记中的资产:最后,在你的JS文档中实例化Lozad:

const observer = lozad();observer.observe();

你将在Lozad GitHub存储库中找到有关如何使用该库的所有详细信息。如果你不想深入了解Intersection Observer API的工作原理,或者只是在寻找适用于各种内容类型的快速实现,则Lozad是一个不错的选择。仅注意浏览器支持,并最终将此库与用于Intersection Observer API的polyfill集成。

4、延迟加载具有模糊的图像效果

你首先看到的是图像的模糊,低分辨率副本,而其高分辨率版本则被延迟加载:你可以通过多种方式来延迟加载具有这种有趣的模糊效果的图像。我最喜欢的技术是Craig Buckler。这是此解决方案的全部优点:

  • 性能:仅463字节的CSS和1,007字节的最小JavaScript代码

  • 支持视网膜屏幕

  • 无依赖关系:不需要jQuery或其他库和框架

  • 逐步增强功能以抵消较旧的浏览器和JavaScript失败

5、 Yall.js

Yall是功能丰富的延迟加载脚本,用于图像,视频和iframe。更具体地说,它使用Intersection Observer API并在必要时巧妙地使用传统的事件处理程序技术。在文档中包含Yall时,需要按以下方式对其进行初始化:

  document.addEventListener("DOMContentLoaded", yall);

接下来,要延迟加载一个简单的img元素,在标记中需要做的就是:请注意以下几点:

  • 你将懒惰的类添加到元素

  • src的值是一个图像占位符

  • 你要延迟加载的图像的路径在src属性内部

Yall的好处包括:

  • Intersection Observer API的出色性能

  • 出色的浏览器支持(可回溯到IE11)

  • 无需其他依赖项

结论

以上就是我分享的关于延迟加载图像的5种方法,你可以开始在项目中进行试验和测试。如果你还有更好的方法,也可以给我留言,我们一起学习进步,最后,感谢你的阅读。

iframe异步加载_5种延迟加载图像的方法以帮助你提升网站性能与用户体验相关推荐

  1. 异步加载js文件并执行js方法:实现异步处理网页的复杂效果

    异步加载js文件并执行js方法:实现异步处理网页的复杂效果 有这么一个场景,当你的网页页面效果过多就会造成了打开页面的速度变得缓慢,长时间处于加载的状态,这样的效果通常会让用户感到不友好,通常的处理方 ...

  2. iframe异步加载技术及性能

    我们会经常使用iframes来加载第三方的内容.广告或者插件.使用iframe是因为它可以和主页面并行加载,不会阻塞主页面.当然使用iframe也是有利有弊的:Steve Souders在他的blog ...

  3. iframe异步加载性能优化及无阻塞加载

    我们会经常使用iframes来加载第三方的内容.广告或者插件.使用iframe是因为它可以和主页面并行加载,不会阻塞主页面. iframe会阻塞主页面的onload事件 主页面和iframe共享同一个 ...

  4. 玩转代码|异步加载 CSS 的最简单方法

    为了提高页面性能和弹性,我们可以做的最有影响力的事情之一:是以不延迟页面呈现的方式加载 CSS.这是因为默认情况下,浏览器会同步加载外部CSS--在下载和解析 CSS 时停止所有页面渲染--这两者都会 ...

  5. Android实现ListView异步加载图片

    转: http://www.iteye.com/topic/685986 ListView异步加载图片是非常实用的方法,凡是是要通过网络获取图片资源一般使用这种方法比较好,用户体验好,下面就说实现方法 ...

  6. Android实现ListView异步加载图片总结

    参考自http://blog.csdn.net/wanglong0537/article/details/6334005# http://www.cnblogs.com/slider/archive/ ...

  7. Android实现异步加载图片 ListView

    转自:http://www.congci.com/item/android-listview-load-image ListView异步加载图片是非常实用的方法,凡是是要通过网络获取图片资源一般使用这 ...

  8. 百度ssp php源码,百度联盟SSP媒体广告异步加载代码最优解决方案

    百度联盟SSP媒体广告异步加载代码最优解决方案 相信很多站长跟我一样,建站之后第一时间就会去做百度.谷歌等联盟广告,原因很简单,就是希望能给自己增加一丢丢的收入,虽然可能几个月才收到100块(百度真小 ...

  9. python 异步加载_Python学习笔记4——爬取异步加载数据

    一.什么是异步加载? 在之前的学习笔记中,爬取的网页是需要手动翻页的网址,但是一些网站是通过自动加载翻页的,如knewone网页.浏览knewone的官网就能发现,当下拉到网页最下端时,网站会自动加载 ...

最新文章

  1. mysql group by 天_MySQL group by语句如何优化
  2. 数据中心电气及自动化(一)
  3. HTTP网页请求过程
  4. Servlet优化之BaseServlet
  5. 修改归档模式的存档终点 archive log list
  6. matlab 列表 剪切,利用Matlab进行文件批量复制、剪切和修改文件名
  7. 使用python套用excel模板_Python自动化办公Excel-从表中批量复制粘贴数据到新表
  8. mysql安装包配置方式_mysql安装包方式安装及配置(Windows)
  9. bp神经网络预测股票价格,bp神经网络股价预测
  10. python爬取微博数据代码_Python selenium爬取微博数据代码实例
  11. 【ArcGIS自定义脚本工具】NDVI批量估算植被覆盖率
  12. 北京挪动推出神州行5元卡套餐
  13. 2分钟完美激活Windows7旗舰版
  14. 无利不起早:理性看待IBM倾“芯”中国
  15. 来,教你开发一款图形编辑器
  16. [锁 Lock] Lock lock = new ReentrantLock()之自增序列号
  17. 多传感器数据融合简介(转)
  18. Brotli压缩算法
  19. 吴军《智能时代》读书笔记
  20. springboot自带的线程池ThreadPoolTaskExecutor、ThreadPoolTaskScheduler的深入应用——异步任务监听回调,任务中断案例

热门文章

  1. mindi linux 使用教程,Linux使用入门教程之tuned
  2. java怎么配置哨兵模式_redis 哨兵模式配置与spring集成
  3. ORA-01858: 在要求输入数字处找到非数字字符 13行
  4. RabbitMQ非root用户安装(Linux环境)
  5. 计算机专业课程群建设,计算机科学与技术专业课程群建设的研究与实践
  6. 2021浙江高考宁波四中成绩查询,2021浙江高考成绩查询时间公布 几号能查分
  7. 记录qt窗口在拖动过程中出现的问题
  8. Qt中多个动态创建的按钮同时绑定一个槽函数,判断被点击的是哪个按钮
  9. java $1参数_jmap命令详解----查看JVM内存使用详情
  10. 调用oracle常用方法,区分Oracle和SQL Server常用函数调用方法