您的位置:首页 > 教程笔记 > 前端笔记

图片懒加载有哪些方法

2021-02-13 03:50:33 前端笔记 64

图片懒加载是一种优化网页性能的技术,它可以延迟加载页面上的图片,只有当图片即将出现在用户的视口中时才加载它们。这样可以减少页面的加载时间,提高用户体验和网站的整体性能。在本文中,我将介绍几种常用的图片懒加载方法。

1. 基于Intersection Observer的懒加载:

Intersection Observer是浏览器提供的一种API,可以监测元素是否进入了用户的视口。通过使用Intersection Observer,我们可以监听图片元素是否可见,当图片进入视口时再加载它们。这种方法不仅简单易用,而且性能较好。

以下是一个使用Intersection Observer实现图片懒加载的示例代码:

// 创建一个Intersection Observer实例
const observer = new IntersectionObserver((entries, observer) => {
  entries.forEach((entry) => {
    if (entry.isIntersecting) {
      // 当图片进入视口时加载它
      entry.target.src = entry.target.dataset.src;
      observer.unobserve(entry.target);
    }
  });
});
// 获取所有需要懒加载的图片元素,并添加观察者
const lazyImages = document.querySelectorAll('.lazy');
lazyImages.forEach((lazyImage) => {
  observer.observe(lazyImage);
});

2. 使用scroll事件监听的懒加载:

这种方法是通过监听滚动事件来判断图片是否进入视口。当用户滚动页面时,检查每张图片的位置是否在视口中,如果是,则加载图片。

以下是一个使用scroll事件监听实现图片懒加载的示例代码:

window.addEventListener('scroll', () => {
  const lazyImages = document.querySelectorAll('.lazy');
  lazyImages.forEach((lazyImage) => {
    if (lazyImage.getBoundingClientRect().top <= window.innerHeight && lazyImage.getBoundingClientRect().bottom >= 0) {
      lazyImage.src = lazyImage.dataset.src;
      lazyImage.classList.remove('lazy');
    }
  });
});

3. 使用setTimeout的懒加载:

这种方法是通过设置一个延迟时间来加载图片。当页面加载完成后,先加载一张占位图片,然后使用setTimeout来延迟加载真实图片,以达到懒加载的效果。

以下是一个使用setTimeout实现图片懒加载的示例代码:

window.addEventListener('load', () => {
  const lazyImages = document.querySelectorAll('.lazy');
  lazyImages.forEach((lazyImage) => {
    lazyImage.src = lazyImage.dataset.placeholder;
    setTimeout(() => {
      lazyImage.src = lazyImage.dataset.src;
      lazyImage.classList.remove('lazy');
    }, 1000); // 设置延迟时间,单位为毫秒
  });
});

相关推荐

  • 怎么使HTML标签在HTML页面正常显示而不被解析的方法

    怎么使HTML标签在HTML页面正常显示而不被解析的方法

    要想html标签在html页面正常显示而不被解析:最简单的方式有4种方法。

    前端笔记 2023-11-17 17:56:07 131
  • wordpress 如何自定义用户注册页面

    wordpress 如何自定义用户注册页面

    wordprss程序自带有注册页面,但很难满足我们自己建网站的需求。我们在做网站时,如何自定义wordprss注册页面呢?下面就是自定义wordprss注册页面的方法。第一步:新建一个HTML空白页面,在HTML页面中,粘贴以下HTML代码,用于显示用户输入框。&

    综合教程 2023-11-16 11:00:49 39
  • WordPress搜索结果怎么屏蔽Page页面和指定分类

    WordPress搜索结果怎么屏蔽Page页面和指定分类

    wordprss网站用户搜索时,会显示所有符合用户需求的内容,包括文章页面和pag页面。那么不希望Pag页面被用户搜索出来的,不想让它显示在搜索结果里。搜索结果屏蔽Pag页面(将以下的代码,放到自己的WordPrss模板的函数文件functions.)搜

    综合教程 2023-11-16 11:00:47 212
  • wordpress不同page页面设置不同模板的方法

    wordpress不同page页面设置不同模板的方法

    wordprss网站上不变的内容可以使用pag页面来制作。比如:公司介绍、联系我们、人才招聘等。在wordprss模板制作教程中也介绍了pag页面制作方法。一般情况下,wordprss后台的页面是自动调用pag.模板的,但是有时为了网站制作的需要,要求不同p

    综合教程 2023-11-16 11:00:37 144
  • WordPress根据ID获取Page页面标题、链接和缩略图

    WordPress根据ID获取Page页面标题、链接和缩略图

    用wordprss做主题时,往往需要通过页面的ID号来获取链接。下面是Wordprss通过ID获取分类和Pag的链接的二种代码。WordPrss通过ID获取Pag页面链接:?chogt_pag_link(1);?除此之外,w

    综合教程 2023-11-16 11:00:21 183