网站图片打开太慢,何为懒加载?原理又是什么?网站图片打开太慢,何为懒加载?原理又是什么?网站图片打开太慢,何为懒加载?原

店小二 楼主 发表于 2023-2-28 02:32:05 显示全部楼层 回复 : 1 浏览 : 1090
店小二 发表于 2023-2-28 02:32:05 | 显示全部楼层 |阅读模式
悬赏1金币 已解决
网站图片打开太慢,何为懒加载?原理又是什么?

最佳答案

风华绝代2023-2-28 02:32:05
1 懒加载的概念 懒加载也叫做 延迟加载、按需加载 ,指的是在长网页中延迟加载图片数据,是一种较好的网页性能优化的方式。在比较长的网页或应用中,如果图片很多,所有的图片都被加载出来,而用户只能看到可视窗口的那一部分图片数据,这样就浪费了性能。 如果使用图片的懒加载就可以解决以上问题。在滚动屏幕之前,可视化区域之外的图片不会进行加载,在滚动屏幕时才加载。这样使得网页的加载速度更快,减少了服务器的负载。懒 ...

查看完整内容>>

风华绝代 发表于 2023-2-28 02:32:06 | 显示全部楼层
1 懒加载的概念

懒加载也叫做 延迟加载、按需加载 ,指的是在长网页中延迟加载图片数据,是一种较好的网页性能优化的方式。在比较长的网页或应用中,如果图片很多,所有的图片都被加载出来,而用户只能看到可视窗口的那一部分图片数据,这样就浪费了性能。

如果使用图片的懒加载就可以解决以上问题。在滚动屏幕之前,可视化区域之外的图片不会进行加载,在滚动屏幕时才加载。这样使得网页的加载速度更快,减少了服务器的负载。懒加载适用于图片较多,页面列表较长(长列表)的场景中。

2 懒加载的特点

减少无用资源的加载:使用懒加载明显减少了服务器的压力和流量,同时也减小了浏览器的负担。
提升用户体验: 如果同时加载较多图片,可能需要等待的时间较长,这样影响了用户体验,而使用懒加载就能大大的提高用户体验。
防止加载过多图片而影响其他资源文件的加载 :会影响网站应用的正常使用。

3 懒加载的实现原理

图片的加载是由src引起的,当对src赋值时,浏览器就会请求图片资源。根据这个原理,我们使用HTML5 的data-xxx属性来储存图片的路径,在需要加载图片的时候,将data-xxx中图片的路径赋值给src,这样就实现了图片的按需加载,即懒加载。

注意:data-xxx 中的xxx可以自定义,这里我们使用data-src来定义。

懒加载的实现重点在于确定用户需要加载哪张图片,在浏览器中,可视区域内的资源就是用户需要的资源。所以当图片出现在可视区域时,获取图片的真实地址并赋值给图片即可。

使用原生JavaScript实现懒加载:
知识点:

(1)window.innerHeight 是浏览器可视区的高度

(2)document.body.scrollTop || document.documentElement.scrollTop 是浏览器滚动过的距离

(3)imgs.offsetTop 是元素顶部距离文档顶部的高度(包括滚动条的距离)

(4)图片加载条件:img.offsetTop < window.innerHeight + document.body.scrollTop;

示例:
<div class="container">
     <img src="loading.gif"  data-src="pic.png">
     <img src="loading.gif"  data-src="pic.png">
     <img src="loading.gif"  data-src="pic.png">
     <img src="loading.gif"  data-src="pic.png">
     <img src="loading.gif"  data-src="pic.png">
     <img src="loading.gif"  data-src="pic.png">
</div>
<script>
var imgs = document.querySelectorAll('img');
function lozyLoad(){
                var scrollTop = document.body.scrollTop || document.documentElement.scrollTop;
                var winHeight= window.innerHeight;
                for(var i=0;i < imgs.length;i++){
                        if(imgs.offsetTop < scrollTop + winHeight ){
                                imgs.src = imgs.getAttribute('data-src');
                        }
                }
        }
  window.onscroll = lozyLoad();
</script>


4 懒加载与预加载的区别

这两种方式都是提高网页性能的方式,两者主要区别是一个是提前加载,一个是迟缓甚至不加载。懒加载对服务器前端有一定的缓解压力作用,预加载则会增加服务器前端压力。

懒加载也叫延迟加载,指的是在长网页中延迟加载图片的时机,当用户需要访问时,再去加载,这样可以提高网站的首屏加载速度,提升用户的体验,并且可以减少服务器的压力。它适用于图片很多,页面很长的电商网站的场景。懒加载的实现原理是,将页面上的图片的 src 属性设置为空字符串,将图片的真实路径保存在一个自定义属性中,当页面滚动的时候,进行判断,如果图片进入页面可视区域内,则从自定义属性中取出真实路径赋值给图片的 src 属性,以此来实现图片的延迟加载。
预加载指的是将所需的资源提前请求加载到本地,这样后面在需要用到时就直接从缓存取资源。 通过预加载能够减少用户的等待时间,提高用户的体验。我了解的预加载的最常用的方式是使用 js 中的 image 对象,通过为 image 对象来设置 scr 属性,来实现图片的预加载。

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Lv.8 超级版主
未知城市| 未知职业
UP主暂无自我介绍,什么也没写!
  • 1关注
  • 2粉丝
  • 1主题

最新帖子

  • 云朵 云朵 2026-06-04

    年年长着标准瓜子脸,双眸明亮,腰身苗条,每当她展露笑颜,嘴角上扬的弧度恰到好处,

  • 樱花草 樱花草 2026-05-29

    你们知道吗?仙女姐姐穿孔雀绿裙真的美炸了!哎,仙女姐姐每次出场都能惊艳全场,这运

  • 风华绝代 风华绝代 2025-05-31

    关晓彤身穿一袭蓝色抹胸开叉长裙,性感妩媚的她雾蓝纱裙裹身,开衩处长腿若隐若现。

  • 大掌柜 大掌柜 2024-12-03

    模特陆萱萱黑色露肩礼裙搭配魅惑黑丝泰国旅拍

  • 大掌柜 大掌柜 2024-04-05

    眼里柔情都是你,爱里落花水飘零。梦里牵手都是你,命里纠结无处醒。 今生君恩还不尽

  • **** 本内容购买后可见 ****

  • 大掌柜 大掌柜 2023-12-28

    全新装修电梯两房,朝南采光好,南北通透,配置齐全,诚心出全新装修电梯两房,朝南采光好

  • 精选图文

    仙女姐姐刘亦菲变身气质女神养眼全白西装酷飒帅气,御姐风美艳动人
    仙女姐姐刘亦菲变身气质女神养眼全
    刘亦菲一头披肩的微卷长发与西装套装搭配即帅气干练又显得优雅大方,与白色圆领T恤渐
    招聘分类帖 清秀甜美美女养眼写真清秀甜美美女养眼写真清秀甜美美女养眼写真清秀甜美美女养眼写真
    招聘分类帖 清秀甜美美女养眼写真
    分享一组清秀甜美美女性感养眼写真图片,浪漫气息与少女心的完美结合,共同诉说青春的
    吴宣仪身着白色钻边刺绣薄纱为什么那么性感?长裙仙气十足精致又性感
    吴宣仪身着白色钻边刺绣薄纱为什么
    女人怎样才可以让自己变得更性感?性感是举手投足之间女人自然就展示出来的柔媚,一个

    加入会员,总有一些美图是您喜欢的

    联系我们 认证会员