什么是懒加载

概念

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

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

特点

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

原理

图片的加载是由src引起的,当对src赋值时,浏览器就会请求图片资源。根据这个原理,我们使用HTML5的data-xxx属性来储存图片的路径,在需要加载图片的时候,将data-xxx中图片的路径赋值给src,这样就实现了图片的按需加载,即懒加载。
注意:data-xxx 中的xxx可以自定义,这里我们使用data-src来定义。
懒加载的实现重点在于确定用户需要加载哪张图片,在浏览器中,可视区域内的资源就是用户需要的资源。所以当图片出现在可视区域时,获取图片的真实地址并赋值给图片即可。

列表数据懒加载 (利用hooks抽取)3

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
export function useLazyData(callBack: () => void) {
 // 通过 ref 获得组件实例
 const target = ref(null)
 const { stop } = useIntersectionObserver(
   // target这个参数是观察的目标dom容器,必须是dom容器,而且是vue3.0方式绑定的dom对象
   target,
   // isIntersecting 是否进入可视区域,true是进入 false是移出
   // observerElement 被观察的dom
  ([{ isIntersecting }]) => {
     // 在此处可根据isIntersecting来判断,然后做业务
     if (isIntersecting) {
       stop()
       callBack()
    }
  }
)
 return target  // 将响应对象作为返回值传递
}

在组件中使用

1
2
3
4
import useStore from '@/store'
import { useLazyData } from '@/utils/hooks';
const { home } = useStore()
const target = useLazyData(() => home.getHotList())

懒加载与预加载的区别

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

  • 懒加载也叫延迟加载,指的是在长网页中延迟加载图片的时机,当用户需要访问时,再去加载,这样可以提高网站的首屏加载速度,提升用户的体验,并且可以减少服务器的压力。它适用于图片很多,页面很长的电商网站的场景。
  • 预加载指的是将所需的资源提前请求加载到本地,这样后面在需要用到时就直接从缓存取资源。 通过预加载能够减少用户的等待时间,提高用户的体验。我了解的预加载的最常用的方式是使用 js 中的 image 对象,通过为 image 对象来设置 scr 属性,来实现图片的预加载。