用IntersectionObserver实现图片懒加载

为了减少网络请求,提升页面加速速度,可以使用懒加载来做优化。


<img src="https://shirtoid.com/wp-content/uploads/2009/09/loading.jpg" alt="">

<script>
    console.log('开始加载图片', new Date().getTime());
    // 分页请求
    // 触发条件再请求

    // 监听图片加载完毕后触发
    var img = new Image();
    img.src = 'https://shirtoid.com/wp-content/uploads/2009/09/loading.jpg';

    img.onload = function () {
      console.log('图片加载完毕...', new Date().getTime());

      document.querySelector('img').src = 'https://tse1-mm.cn.bing.net/th/id/OIP-                
       C.iP738K4uYOe1mViOLprM2QHaE8?pid=ImgDet&rs=1';

    }

    console.log('代码执行完毕', new Date().getTime());
 </script>

还可以通过js提供的IntersectionObserver构造函数来监听实现懒加载,它的参数是一个回调函数,其默认参数有个isIntersecting属性,可以通过这个属性来判断容器元素是否在可视区域内;它还有一些方法,IntersectionObserver.observe()开始监听一个目标元素,IntersectionObserver.unobserve()停止监听特定目标元素。IntersectionObserver.unobserve()IntersectionObserver.observe()

IntersectionObserver - Web API 接口参考 | MDN

<template>
    <div class="container" v-for="(item, index) in newList" :key="index">
        <div class="imgbox">
            <img v-img-lazy="item" alt="">
        </div>
    </div>
</template>
<script setup>

// 获取图片资源
const imgList = import.meta.glob('@/assets/images/*.*', { eager: true })

// 转为数组
let newList = Object.values(imgList).map(el => el.default)

const vImgLazy = async (el, binding) => {
    const def = await import('@/assets/logo.svg')
    el.src = def.default

    const ob = new IntersectionObserver(entries => {
        // console.log(entries);
        if (entries[0].isIntersecting) {
            setTimeout(() => {
                el.src = binding.value

                // 停止监听
                ob.unobserve(el)
            }, 1000)
        }
    })

    ob.observe(el)
}
</script>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
IntersectionObserver是一种新的API,可以用于实现懒加载。懒加载是指在页面滚动时,只加载可视区域内的内容,而不是一次性加载所有内容。这样可以优化网页加载速度,提升用户体验。 下面是IntersectionObserver实现懒加载的步骤: 1. 创建一个IntersectionObserver对象:可以通过其构造函数创建。 2. 选取需要进行懒加载的图片或其他DOM元素,将其包裹在一个容器元素中。 3. 使用IntersectionObserver对象的observe方法来观察容器元素。 4. 在回调函数中获取到可见性变化的元素,如果元素进入可视区域,就将其src属性指向真实图片的地址,实现图片的懒加载。 下面是一个示例代码: ``` let lazyImages = document.querySelectorAll('.lazy-image'); let options = { root: null, // 窗口视图作为根元素 rootMargin: '0px', // 不添加边框 threshold: 0.1 // 当可见性达到10%时触发回调 }; let observer = new IntersectionObserver(function(entries, observer) { entries.forEach(entry => { if (entry.isIntersecting) { // 元素进入可见视图 let lazyImage = entry.target; lazyImage.src = lazyImage.dataset.src; observer.unobserve(lazyImage); // 取消观察 } }); }, options); lazyImages.forEach(lazyImage => { observer.observe(lazyImage); }); ``` 在上面的代码中,我们首先选取了所有带有lazy-image类的图片元素,然后创建了一个IntersectionObserver对象,指定了观察的根元素和触发回调的阈值。接着,我们遍历了所有图片元素,使用observe方法观察了每个元素。在回调函数中,我们判断元素是否进入了可视区域,如果是,就将该元素的data-src属性值赋给src属性,实现懒加载,然后取消对该元素的观察。最后,我们通过forEach方法将所有图片元素添加到IntersectionObserver的观察列表中。 注意,容器元素的宽高需要在CSS中指定,否则IntersectionObserver无法准确计算元素的可见性。同样,图片元素的真实地址需要通过data-src属性指定,而不是src属性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值