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

e0e06e219476715bacdc816425b6b1fe.png

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

什么是延迟加载?

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

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

至少有两个极好的原因,你应该考虑为网站延迟加载图像:
  • 如果你的网站使用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、延迟加载具有模糊的图像效果

你首先看到的是图像的模糊,低分辨率副本,而其高分辨率版本则被延迟加载:d3601c79ed4ffdd23fd7220faaff45f5.png15fb90783b47778350f78e030036160b.png你可以通过多种方式来延迟加载具有这种有趣的模糊效果的图像。我最喜欢的技术是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种方法,你可以开始在项目中进行试验和测试。如果你还有更好的方法,也可以给我留言,我们一起学习进步,最后,感谢你的阅读。d525f4626c2a4fef99bfb5c78073ee17.pnge7ac4abff8f145a2e3b47b5d5b5d49f4.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/532095.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

springframework报错_应对报错信息的必杀技!

今天遇到了一个错误&#xff0c;一般的错误提示会很明显&#xff0c;一看就知道是什么问题。今天遇到的这个说实话真的不好找原因&#xff0c;一般在这种情况下该怎么解决呢&#xff1f;分享下我的思路吧&#xff0c;不一定是最好的&#xff0c;至少有用。直接上图吧&#xff0…

电脑运行卡顿怎么处理_【众点学】电脑运行PS卡顿?可能是你的虚拟内存没设置好!...

不少小伙伴都遇到过这样的烦恼明明自己的电脑拥有大内存PS用着用着就卡顿了经过教体君的仔(bai)细(du)研(yi)究(xia)发现原来电脑的 虚拟内存 只有2G当我们用大型软件或玩大型游戏电脑越用越卡时该怎么做&#xff1f;今天【众点学】我们一起来看看Win7和Win10系统下分别如何设置…

线程池拒绝策略 开发中常用什么策略_面试官:说说你知道多少种线程池拒绝策略...

往期文章为什么阿里Java规约要求谨慎使用SimpleDateFormathttps://www.toutiao.com/i6696127929048367629/为什么我强烈推荐你用枚举来实现单例模式https://www.toutiao.com/i6696861933687013901/为什么不要在MySQL中使用UTF-8编码方式https://www.toutiao.com/i6697966437727…

css html 双面打印_从 Linux 命令行进行打印 | Linux 中国

导读&#xff1a;在 Linux 命令行进行打印的内容比单单一个 lp 命令多得多&#xff0c;让我们来看一些可用选项。       本文字数&#xff1a;4305&#xff0c;阅读时长大约&#xff1a;5分钟https://linux.cn/article-13012-1.html作者&#xff1a;Sandra Henry-stocker译…

服务器内存超限问题_服务器内存爆满最佳处置方案

内存爆满截图&#xff1a;分析&#xff1a;内存持续飙升&#xff0c;应该是有大量内存一直没有释放&#xff0c;考虑僵尸对象&#xff0c;僵尸进程&#xff0c;最简单的就是重启服务器&#xff0c;但是就无法找到罪魁祸首了。验证&#xff1a;top命令查看活跃进程的资源使用情况…

js map对象遍历_何时使用 Map 来代替变通的 JS 对象

JS 普通对象 {key: value} 用于存放结构化数据。但有一件事我觉得很烦:对象键必须是字符串(或很少使用的 symbol)。如果将数字用作键会怎样&#xff1f;在这种情况下不会有错误&#xff1a;const names { 1: One, 2: Two,};Object.keys(names); // > [1, 2]JS 会隐式地将…

mysql怎么显示结果窗口_mysql8中窗口函数

在以前的MySQL版本中是没有窗口函数的&#xff0c;直到MySQL8.0才引入了窗口函数。窗口函数是对查询中的每一条记录执行一个计算&#xff0c;并且这个计算结果是用与该条记录相关的多条记录得到的。1.窗口函数与聚合函数窗口函数与聚合函数很像&#xff0c;他们都是在一组记录而…

log4jdbc mysql_[简单]log4jdbc-log4j2配置简记_MySQL

log4jdbc-log4j2&#xff0c;就不多说了&#xff0c;不了解的可以谷歌&#xff0c;附上log4jdbc-log4j2的官方链接&#xff1a;https://code.google.com/p/log4jdbc-log4j2/ &#xff0c;上面有非常详细的介绍。简单的贴下配置文件&#xff0c;其他的见附件&#xff1a;databas…

vb实时错误6 溢出_java内存溢出系列(6): Out of swap space?

本文是java内存溢出系列第6小篇。JVM启动参数指定了最大内存限制。如 -Xmx 以及相关的其他启动参数. 假若JVM使用的内存总量超过可用的物理内存, 操作系统就会用到虚拟内存。错误信息 java.lang.OutOfMemoryError: Out of swap space? 表明, 交换空间(swap space,虚拟内存) 不…

java备份还原mysql数据库_Java备份还原Mysql数据库

///实体类package com.ews.util;/*** 系统备份展示对象** */public class DataFile {private String fileName;//备份文件的名称private String fileDate;//备份文件的日期private String filePath;//备份文件的地址private String fileSize;//备份文件的大小public String get…

mysql 查看锁_别吵吵,分布式锁也是锁

Tomcat是这个系统的核心组成部分&#xff0c; 每当有用户请求过来&#xff0c;Tomcat就会从线程池里找个线程来处理&#xff0c;有的执行登录&#xff0c;有的查看购物车&#xff0c;有的下订单&#xff0c;看着属下们尽心尽职地工作&#xff0c;完成人类的请求&#xff0c;Tom…

php解析js的 arraybuffer_JS的所谓的第七种数据类型Symbol

首先&#xff0c;为什么说叫所谓呢&#xff1f;因为在2007年之前Js给予我们typeof解析数据类型的一共有六种(一直有争议&#xff0c;但是我们暂时就按typeof来算)functionNumberObjectbooleanStringundefined但当我们去 typeof Symbol () 的时候&#xff0c;会惊奇的发现&#…

Ubuntu系统如何安装和卸载CUDA和CUDNN

背景 最近在学习PaddlePaddle在各个显卡驱动版本的安装和使用&#xff0c;所以同时也学习如何在Ubuntu安装和卸载CUDA和CUDNN&#xff0c;在学习过程中&#xff0c;顺便记录学习过程。在供大家学习的同时&#xff0c;也在加强自己的记忆。本文章以卸载CUDA 8.0 和 CUDNN 7.05 …

session.merge 缓存不更新_如何保证缓存与数据库双写时的数据一致性?

在做系统优化时&#xff0c;想到了将数据进行分级存储的思路。因为在系统中会存在一些数据&#xff0c;有些数据的实时性要求不高&#xff0c;比如一些配置信息。基本上配置了很久才会变一次。而有一些数据实时性要求非常高&#xff0c;比如订单和流水的数据。所以这里根据数据…

java替换图片中文字_Java 添加、替换、删除Word中的图片

文档中&#xff0c;可以通过图文混排的方式来增加内容的可读性&#xff0c;相比纯文本文档&#xff0c;在内容展现方式上也更具美观性。在给文档添加图片时&#xff0c;可设置图片的文本环绕方式、旋转角度、图片高度/宽度等&#xff1b;另外&#xff0c;也可对文档中已有的图片…

kafka如何保证不重复消费又不丢失数据_Kafka写入的数据如何保证不丢失?

我们暂且不考虑写磁盘的具体过程&#xff0c;先大致看看下面的图&#xff0c;这代表了 Kafka 的核心架构原理。Kafka 分布式存储架构那么现在问题来了&#xff0c;如果每天产生几十 TB 的数据&#xff0c;难道都写一台机器的磁盘上吗?这明显是不靠谱的啊!所以说&#xff0c;这…

不允许输入特殊字符的正则表达式_JavaScript正则表达式常用技巧

正则表达式是用于匹配字符串中字符组合的模式。在 JavaScript 中&#xff0c;正则表达式也是对象。这些模式被用于 RegExp 的 exec 和 test 方法, 以及 String 的 match、matchAll、replace、search 和 split 方法。正则表达式的掌握程度能粗略地看出程序员的技术底子&#xff…

latex 算法_GitHub项目awesome-latex-drawing新增内容(四):绘制贝叶斯网络

近期&#xff0c;我们整理和开源了一个基于LaTeX的科技绘图项目&#xff0c;并将其取名为awesome-latex-drawing&#xff08;GitHub网址为&#xff1a;https://github.com/xinychen/awesome-latex-drawing&#xff09;&#xff0c;案例包括贝叶斯网络、图模型、矩阵/张量示意图…

mysql中的生日应该是什么类型_MySQL中的定点数类型

上一篇文章我们唠叨了浮点数&#xff0c;知道了浮点数存储小数是不精确的。本篇继续唠叨一下MySQL中的另一种存储小数的方式 —— 定点数。浮点数文章闪现&#xff1a;什么, 0.3 - 0.2 ≠ 0.1 ? 什么鬼定点数类型正因为用浮点数表示小数可能会有不精确的情况&#xff0c;在一些…

string转为char数组_StringBuilder的区别是什么?String是不可变?一点课堂(多岸学院)...

String和StringBuffer、StringBuilder的区别可变性简单的来说&#xff1a;String 类中使用 final 关键字字符数组保存字符串&#xff0c;private final char value[]&#xff0c;所以 String 对象是不可变的。而StringBuilder 与 StringBuffer 都继承自 AbstractStringBuild…