首页 web前端 js教程 详细了解JavaScript中的延迟加载

详细了解JavaScript中的延迟加载

Nov 05, 2020 pm 05:59 PM
javascript 延迟加载

详细了解JavaScript中的延迟加载

在这篇文章中,我们将看看延迟加载在web上是如何工作的。我们将介绍本地延迟加载API——延迟加载是如何实现的,延迟加载的重要性和优点,最后是一个简单的延迟加载web内容用例。

理解延迟加载API及其工作方式将帮助已经使用实现这些技术的库和框架的开发人员了解底层的情况。此外,如果他们打算实现自己的延迟加载库,他们将能够执行更多的指导研究并应用他们学到的技术。

对于一个真实的用例,那些通过平台上的广告获得收入的营销和广告公司可以很容易地优化和应用延迟加载,从而很容易地判断哪些广告被访问他们平台的用户看到,从而做出更好的商业决策。

推荐教程:《JavaScript视频教程

什么是延迟加载?

根据Wikipedia的介绍,延迟加载是一种设计模式,用于在需要时推迟元素或对象的初始化。这意味着仅当用户在网页上滚动时,相对于父DOM元素的目标DOM元素才被加载并可见(当两个元素之间存在交集时,基于设置的阈值)。

不采用这种模式的缺点可能导致:

  • 由于从一个或多个源获取多个图像或其他web资源的多个同步网络请求或批处理请求,导致页面性能严重滞后

  • 由于要下载/获取的包的大小而增加页面加载时间

  • 用户保留率低,主要适用于互联网连接较差的地区。当我们开发人员犯了不尽早实现延迟加载的错误时,用户完全避免使用平台的情况并不少见

  • 由于图像、iframe和视频等资源或资产处理不当,对web性能和可访问性造成巨大影响

目前,大多数现代和更新的浏览器在web上都支持延迟加载。但是,对于还没有提供这种支持的浏览器,实现这种技术的填充或库在它们之上提供了简单的API层。

延迟加载解决了减少初始页面加载时间的问题-仅显示用户在初始化网页时以及随后滚动页面时需要查看的资源,例如图像或其他内容。

众所周知,Web性能和可访问性问题是多方面的;减少页面大小、内存占用和一般的加载时间可以为web平台做出很大贡献。当我们有一堆图像和视频,并且在浏览器DOM初始化时一次性加载它们时,延迟加载的优点就变得很明显了。

当然,您现在应该已经理解了这将导致什么,正如我们前面所讨论的。

从数据来看,大多数网站都严重依赖图像和其他网络内容,比如视频或iframe,来将信息传递给目标受众。虽然这可能看起来琐碎而简单,但是我们向用户显示这些内容的方式最终决定了我们的平台的性能。

此外,有助于优化页面加载时间的操作(比如依赖于用户是否滚动到页面特定部分的事件)是延迟加载的一些用例。随着本文的继续,我们将更多地了解现实环境中的其他用例。

本机延迟加载API

延迟加载构建在交集观察者API的基础上,交集观察者API是一种浏览器API,它提供了一种方法来检测或知道一个称为目标、父元素的元素何时在浏览器视口内可用或可见(视情况而定)。

当这种情况发生时,将调用处理程序函数来帮助处理代码逻辑的其他部分,稍后我们将看到这一点。

有了这个新的和改进的浏览器API,我们还可以知道两个DOM元素何时相交——这里的意思是,目标DOM元素何时进入浏览器的视口,或者与另一个元素(很可能是它的父元素)相交。

为了更好地理解延迟加载是如何工作的,我们首先必须理解如何创建一个交集观察者。为了创建一个交集观察者,我们所需要做的就是侦听交集观察者事件的发生,并在这种事件发生时触发一个回调函数或处理程序来运行。

交集观察者事件是一种类似于文档事件类别的浏览器事件,其中包括DOMContentLoaded事件。

注意:对于交集事件,我们需要指定要应用交集的元素。这个元素通常被称为根元素。但是,如果没有指定根元素,则意味着我们打算针对整个浏览器窗口。

此外,我们还需要为根元素指定一个空白(如果提供了),以便在必要时可以在交集上轻松地更改其形状或大小。让我们看一个例子来更好地理解它:

let options = {
root: null,
rootMargin: 10px,
threshold: 1.0
}

let observer  = new IntersectionObserver (options, callback);
登录后复制

在上面的代码片段中,我们看到了一个用于创建观察者的简单用例。options对象帮助我们定义目标的自定义属性。

这里,options对象中的threshold属性表示何时触发回调。它的默认值为0,这意味着一旦用户接近目标元素并且它变得可见,就会触发回调。

另一方面,根元素是父元素,当目标元素在用户滚动网页时对用户可见时,根元素充当目标元素的视区。注意,如果根设置为空,父元素将自动成为视区。

最后,rootMargin帮助设置根元素周围的空白。例如,在计算目标元素和父元素/viewport之间的交集之前,可能需要调整它的大小、边距或维数。

而且,接受两个输入参数的回调包括一个我们打算应用于目标元素和调用回调的观察者的intersectionObserverEntry对象列表。

回调的签名如下:

let callback = (entries, observer) => {
entries.forEach(entry => {
If (entry.isIntersection) {
// do some magic here
}
// and some other methods
})
}
登录后复制

该intersectionObserverEntry对象表示父元素和目标元素之间存在交集。它有一堆的API中的属性,其中包括isIntersectionintersectionRatiointersectionRecttargettime,等。

我们需要针对特定的DOM元素,并在它与父元素相交时触发回调函数。目标DOM元素的一个例子如下面的代码片段所示:

let target = document.querySelector("#targetElement");
登录后复制

在上面的代码片段中,我们创建了一个目标元素并为它分配了一个变量。之后,我们使用intersectionObserver构造函数/函数签名上的observe方法观察目标元素,如下所示:

// start observing for changes on the target element
observer.observe(target);
登录后复制

当观察者为目标设置的阈值达到时,将触发回调。

最后,observe()方法告诉观察者要观察什么目标元素。请注意,交集观察者在它的API中同样有一堆方法:unObserve()takeRecords()observe()等是一些例子。

延迟加载技术的优点

现在,我们必须更好地理解为什么延迟加载web内容和资产是必要的。让我们来看看使用这种技术的一些进一步的优势:

  • 构建可高度访问的web应用程序。关于web可访问性的讨论是今天的首要任务。使用这种技术肯定有助于建立一个范围更广的平台

  • 高用户保留。如果web平台与驱动业务目标以及提供价值相关联,那么实现这种技术将有助于使平台变得更加用户友好。web标准稍后会感谢您的!

  • 作为开发人员,您可能需要在web平台上实现无限滚动。理解这一概念将大有帮助,从而提供即时的业务价值

实施延迟加载

让我们来看一个在网页上延迟加载图像的简单例子。我们将开始自定义的选项对象的目标元素,我们打算观察的交集:

let  options = {
root: document.querySelector('.root'),
rootMargin: '0px, 0px, 100px, 0px'
};
登录后复制

现在,对于目标元素,我们来定位几个图像:

let  images = [...document.querySelectorAll('.targetImages')];
登录后复制

现在,让我们看看实现回调:

const callback = (entries) => {

entries.forEach(entry => {
 If (entry.isIntersecting) {
    observer.unObserve('entry.target');
}
// handle other code logic here 
})
}
登录后复制

我们可以继续调用交集观察者构造函数来观察目标元素,基于它的options对象中指定的定制:

let observer = new intersectionObserver(options, callback);
登录后复制

最后,我们可以观察到要观察的目标元素:

images.forEach(image => {
observer.observe(image);
})
登录后复制

注意:为了简单起见,这里不包括HTML和CSS代码。通过在MDN文档中查看此示例,您可以详细了解如何实现此技术。

总结

现在,当我们在网页上有一堆图像或视频,并在浏览器DOM初始化时加载它们时,这种技术的优势就会非常明显。作为开发人员,我们有责任确保我们管理或维护的平台的最佳性能,特别是当它们与业务目标相关联时。

作为一种web性能技术,延迟加载有助于解决这类问题。

更多编程相关知识,请访问:编程入门!!

以上是详细了解JavaScript中的延迟加载的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆树的耳语 - 如何解锁抓钩
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1666
14
CakePHP 教程
1425
52
Laravel 教程
1325
25
PHP教程
1273
29
C# 教程
1252
24
Spring Data JPA 的架构和工作原理是什么? Spring Data JPA 的架构和工作原理是什么? Apr 17, 2024 pm 02:48 PM

SpringDataJPA基于JPA架构,通过映射、ORM和事务管理与数据库交互。其存储库提供CRUD操作,派生查询简化了数据库访问。此外,它使用延迟加载,仅在必要时检索数据,从而提高了性能。

Linux 动态链接与静态链接原来是这么回事? Linux 动态链接与静态链接原来是这么回事? Feb 05, 2024 pm 05:45 PM

老规矩,先提出几个问题:为什么要进行动态链接?如何进行动态链接?什么是地址无关代码技术?什么是延迟绑定技术?如何在程序运行过程中进行显式链接?为什么要进行动态链接?动态链接的出现是为了解决静态链接的一些缺点:节约内存和磁盘空间:如下图所示,Program1和Program2分别包含Program1.o和Program2.o两个模块,他们都需要Lib.o模块。静态链接情况下,两个目标文件都用到Lib.o这个模块,所以它们同时在链接输出的可执行文件Program1和program2中有副本,同时运行

解码Laravel性能瓶颈:优化技巧全面揭秘! 解码Laravel性能瓶颈:优化技巧全面揭秘! Mar 06, 2024 pm 02:33 PM

解码Laravel性能瓶颈:优化技巧全面揭秘!Laravel作为一款流行的PHP框架,为开发者提供了丰富的功能和便捷的开发体验。然而,随着项目规模增大和访问量增加,我们可能会面临性能瓶颈的挑战。本文将深入探讨Laravel性能优化的技巧,帮助开发者发现并解决潜在的性能问题。一、数据库查询优化使用Eloquent延迟加载在使用Eloquent查询数据库时,避免

Java JPA 性能优化秘籍:让你的应用程序飞起来 Java JPA 性能优化秘籍:让你的应用程序飞起来 Feb 19, 2024 pm 09:03 PM

文章关键字:JavaJPA性能优化ORM实体管理JavaJPA(JavaPersistanceapi)是一种对象关系映射(ORM)框架,它允许你使用Java对象来操作数据库中的数据。JPA提供了与数据库交互的统一API,使得你可以使用同样的代码访问不同数据库。此外,JPA还支持懒加载、缓存和脏数据检测等特性,可以提高应用程序的性能。然而,如果使用不当,JPA性能可能会成为你应用程序的瓶颈。以下是一些常见的性能问题:N+1查询问题:当你在应用程序中使用JPQL查询时,可能遇到N+1查询问题。在这种

Hibernate 如何优化数据库查询性能? Hibernate 如何优化数据库查询性能? Apr 17, 2024 pm 03:00 PM

优化Hibernate查询性能的技巧包括:使用延迟加载,推迟加载集合和关联对象;使用批处理,组合更新、删除或插入操作;使用二级缓存,将经常查询的对象存储在内存中;使用HQL外连接,检索实体及其相关实体;优化查询参数,避免SELECTN+1查询模式;使用游标,以块的方式检索海量数据;使用索引,提高特定查询的性能。

如何阻止iframe加载事件 如何阻止iframe加载事件 Feb 19, 2024 am 08:02 AM

如何防止iframe加载事件在网页开发中,我们常常会使用iframe标签来嵌入其他网页或内容。默认情况下,当浏览器加载iframe时,会触发加载事件。然而,在某些情况下,我们可能希望延迟加载iframe,或者完全阻止加载事件。在本文中,我们将探讨如何通过代码示例来实现这个目标。一、延迟加载iframe如果要延迟加载iframe,我们可以使用

Java JPA 开源项目推荐:为你的项目注入新的活力 Java JPA 开源项目推荐:为你的项目注入新的活力 Feb 20, 2024 am 09:09 AM

在Java编程领域,JPA(JavaPersistenceapi)作为一种流行的持久化框架,为开发者提供了对关系型数据库进行操作的便捷方式。通过使用JPA,开发者可以轻松地将Java对象持久化到数据库中,并从数据库中检索数据,从而极大地提高了应用程序的开发效率和维护性。本文精心挑选了10个高质量的JavaJPA开源项目,涵盖了各种不同的功能和应用场景,旨在为开发者提供更多的灵感和解决方案,助力打造更高效和可靠的应用程序。这些项目包括:SpringDataJPA:springDataJPA是Spr

html图片过大怎么办 html图片过大怎么办 Apr 05, 2024 pm 12:24 PM

优化 HTML 图片过大的方法有:优化图像文件大小:使用压缩工具或图像编辑软件。使用媒体查询:根据设备动态调整图像大小。实现延迟加载:仅在图像进入可视区域时加载。使用 CDN:将图像分发到多个服务器。使用图像占位符:在图像加载时显示占位图像。使用缩略图:显示图像的较小版本并单击后加载全尺寸图像。

See all articles