0

0

在JS中如何实现非首屏图片延迟加载

亚连

亚连

发布时间:2018-06-13 14:50:07

|

1817人浏览过

|

来源于php中文网

原创

下面我就为大家分享一篇用js实现非首屏图片延迟加载的示例,具有很好的参考价值,希望对大家有所帮助。

目标

减少资源加载可以明显的优化页面加载的速度,所以可以减少页面载入时立即下载的图片的数量,以提高页面加载速度,其他的图片在需要的时候再进行加载。

思路

想要实现以上的目标,有几个地方需要思考。

1、如何判断哪些图片需要立即加载,哪些可以晚些再加载?

2、如何控制图片在指定的时候加载?

对于第一个问题,页面打开就会被用户看到的图片肯定需要立即加载,其他的可以延后。即在视窗中的图片需要立即加载。那么如何判断图片是否在视窗内呢?getBoundingClientRect可以返回元素的大小及其相对于视口的位置(详细说明)

 

可以通过图中top和right的值判断图片是否在视窗中。

对于第二个问题,先不给img指定src,而是将图片链接地址存放再元素的src属性(自定义)中,需要加载的时候再赋值给src,才会开始下载图片。

实现

思路有了,我们开始实现。用以下HTML进行测试


 

图片懒加载

测试性配文,测试图片懒加载

AI Content Detector
AI Content Detector

Writer推出的AI内容检测工具

下载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

@@##@@

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

@@##@@

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

@@##@@

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

@@##@@

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

@@##@@

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

测试性配文,测试图片懒加载

html中链接都来自百度图片,可在network中观察是否加载,这里忽略样式。按照之前的思路,有以下代码

//所有的图片
 var imgs = document.querySelectorAll('.lazy-img');
 //首屏图片加载
 lazyLoad(imgs)
 //剩余图片加载---监听滚动事件
 window.addEventListener('scroll',function(){
 //滚动事件触发太频繁了,所以加上节流
 throttle(lazyLoad(imgs),200,500)
 })
 }

下面就是如何实现lazyLoad

function lazyLoad(imgs,offset){
 offset = offset || 100;
 if (!imgs || imgs.length < 1) {
 console.log('imgs为空');
 return ;
 }
 [].slice.call(imgs).forEach(function(element,index){
 //元素的DomRect
 var rect = element.getBoundingClientRect()
 //出现在视窗中
 if (rect.top <= window.innerHeight + offset && rect.right > 0) {
 element.setAttribute('src',element.getAttribute('src'))
 }
 })
}

通过window.innerHeight获取到视窗的高度,当元素距离视窗上边沿为offset时,加载图片;其中offset为指定的偏移距离。

节流函数如下

function throttle (fn, delay, atleast) {
 let timer = null
 let startTime = new Date()

 return function () {
 let context = this
 let args = arguments
 let curTime = new Date()

 clearTimeout(timer)
 if (curTime - startTime >= atleast) {
 fn.apply(context, args) // apply 指定函数指向的 上下文(this) 和 参数列表
 startTime = curTime
 } else {
 timer = setTimeout(function () {
 fn.apply(context, args)
 startTime = curTime
 }, delay)
 }
 }
 }

效果

页面载入完成,只加载了一张图片

在JS中如何实现非首屏图片延迟加载

向下滚动到指定位置,才会依次加载后续图片

在JS中如何实现非首屏图片延迟加载

以上这篇JS实现非首屏图片延迟加载的示例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持本站。

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

在JS中如何实现碰撞检测

使用vue-meta如何管理头部标签

在vue中如何修改a标签样式?

有关ES6的7个实用技巧有哪些?

在JS中如何实现非首屏图片延迟加载在JS中如何实现非首屏图片延迟加载在JS中如何实现非首屏图片延迟加载

相关专题

更多
html版权符号
html版权符号

html版权符号是“©”,可以在html源文件中直接输入或者从word中复制粘贴过来,php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

609

2023.06.14

html在线编辑器
html在线编辑器

html在线编辑器是用于在线编辑的工具,编辑的内容是基于HTML的文档。它经常被应用于留言板留言、论坛发贴、Blog编写日志或等需要用户输入普通HTML的地方,是Web应用的常用模块之一。php中文网为大家带来了html在线编辑器的相关教程、以及相关文章等内容,供大家免费下载使用。

646

2023.06.21

html网页制作
html网页制作

html网页制作是指使用超文本标记语言来设计和创建网页的过程,html是一种标记语言,它使用标记来描述文档结构和语义,并定义了网页中的各种元素和内容的呈现方式。本专题为大家提供html网页制作的相关的文章、下载、课程内容,供大家免费下载体验。

466

2023.07.31

html空格
html空格

html空格是一种用于在网页中添加间隔和对齐文本的特殊字符,被用于在网页中插入额外的空间,以改变元素之间的排列和对齐方式。本专题为大家提供html空格的相关的文章、下载、课程内容,供大家免费下载体验。

245

2023.08.01

html是什么
html是什么

HTML是一种标准标记语言,用于创建和呈现网页的结构和内容,是互联网发展的基石,为网页开发提供了丰富的功能和灵活性。本专题为大家提供html相关的各种文章、以及下载和课程。

2887

2023.08.11

html字体大小怎么设置
html字体大小怎么设置

在网页设计中,字体大小的选择是至关重要的。合理的字体大小不仅可以提升网页的可读性,还能够影响用户对网页整体布局的感知。php中文网将介绍一些常用的方法和技巧,帮助您在HTML中设置合适的字体大小。

503

2023.08.11

html转txt
html转txt

html转txt的方法有使用文本编辑器、使用在线转换工具和使用Python编程。本专题为大家提供html转txt相关的文章、下载、课程内容,供大家免费下载体验。

311

2023.08.31

html文本框代码怎么写
html文本框代码怎么写

html文本框代码:1、单行文本框【<input type="text" style="height:..;width:..;" />】;2、多行文本框【textarea style=";height:;"></textare】。

423

2023.09.01

Golang gRPC 服务开发与Protobuf实战
Golang gRPC 服务开发与Protobuf实战

本专题系统讲解 Golang 在 gRPC 服务开发中的完整实践,涵盖 Protobuf 定义与代码生成、gRPC 服务端与客户端实现、流式 RPC(Unary/Server/Client/Bidirectional)、错误处理、拦截器、中间件以及与 HTTP/REST 的对接方案。通过实际案例,帮助学习者掌握 使用 Go 构建高性能、强类型、可扩展的 RPC 服务体系,适用于微服务与内部系统通信场景。

8

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.3万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号