首页 > web前端 > js教程 > 正文

使用Intersection Observer实现懒加载_javascript技巧

betcha
发布: 2025-11-02 23:59:35
原创
418人浏览过
使用Intersection Observer API实现图片懒加载,通过监听元素进入视口触发图片加载,相比传统scroll事件更高效。首先为img标签设置data-src存储真实地址,src指向占位图;然后创建Observer实例,当目标元素可见时将其src替换为data-src,并移除lazy类且停止观察;最后可通过CSS添加淡入过渡效果提升体验。该方法避免频繁重排,性能更优,推荐结合loading="lazy"做兼容处理。

使用intersection observer实现懒加载_javascript技巧

页面加载大量图片时,性能容易下降。懒加载是一种优化手段,让图片在进入视口时才开始加载,从而减少初始资源请求。使用 Intersection Observer API 实现懒加载,比传统监听 scroll 事件更高效、更流畅。

1. 原理:Intersection Observer 是什么?

Intersection Observer 是浏览器提供的 API,用于异步监听目标元素与视口的交叉状态。当目标元素即将或已经进入可视区域时,回调函数会被触发,适合用来实现懒加载。

相比手动计算 offsetTop 和 scrollTop,它性能更好,不会频繁触发重排或重绘

2. HTML 结构:标记待加载图片

给 img 标签设置一个临时属性(如 data-src)存放真实图片地址,src 先指向占位图或为空。

立即学习Java免费学习笔记(深入)”;

<img class="lazy"  src="/images/placeholder.png" alt="图片1">
<img class="lazy"  src="/images/placeholder.png" alt="图片2">
登录后复制

3. JavaScript 实现懒加载逻辑

创建 Intersection Observer 实例,监听所有带有 .lazy 类的图片。

巧文书
巧文书

巧文书是一款AI写标书、AI写方案的产品。通过自研的先进AI大模型,精准解析招标文件,智能生成投标内容。

巧文书61
查看详情 巧文书
const lazyImages = document.querySelectorAll('img.lazy');

const imageObserver = new IntersectionObserver((entries, observer) => {
  entries.forEach(entry => {
    if (entry.isIntersecting) {
      const img = entry.target;
      const src = img.dataset.src;

      if (src) {
        img.src = src;
        img.classList.remove('lazy');
      }

      // 加载完成后停止观察
      observer.unobserve(img);
    }
  });
});

// 开始观察每一张懒加载图片
lazyImages.forEach(img => {
  imageObserver.observe(img);
});
登录后复制

4. 提高体验:添加加载过渡效果

可以在图片加载过程中添加淡入效果,提升视觉体验。

先在 CSS 中定义类:

img {
  opacity: 1;
  transition: opacity 0.3s;
}

img.lazy {
  opacity: 0;
}
登录后复制

图片加载完成后,自然从透明变为可见,实现平滑显示。

基本上就这些。用 Intersection Observer 实现懒加载不复杂但容易忽略细节,比如及时取消观察避免重复操作。这种方式兼容现代主流浏览器,配合 loading="lazy"(原生懒加载)可做降级处理,是目前推荐的做法。

以上就是使用Intersection Observer实现懒加载_javascript技巧的详细内容,更多请关注php中文网其它相关文章!

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

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