vue3 封装组件 ——懒加载

图片的懒加载功能是通过IntersectionObserver来实现的。

以下是封装的组件

<template>
  <div>
    <img :src="placeholderImage" alt="" :data-src="src" ref="lazyimg" />
  </div>
</template>

<script>
import { onMounted, ref } from 'vue'

export default {
  props: {
    src: {
      type: String,
      required: true
    }
  },
  setup() {
    const placeholderImage = ref('')
    const lazyimg = ref(null)

    const Lazy = () => {
      // 创建 IntersectionObserver 实例
      const observer = new IntersectionObserver((entries) => {
        entries.forEach((entry) => {
          if (entry.isIntersecting) {
            // isIntersecting是 是否进入可视区 true
            // 判断进入可视区时,将被观察的targe 的值img
            // 当在HTML中使用data-前缀定义自定义数据属性时,
            // 可以通过dataset属性访问这些属性的值。
            // 当进入可视区时 将自定义的数据 dataset 赋给src
            const img = entry.target
            img.src = img.dataset.src // 将 data-src 的值赋给 src,实现图片加载
            observer.unobserve(img) // 停止对元素的观察
          }
        })
      })

      observer.observe(lazyimg.value) // 开始观察 lazyimg 元素
    }

    onMounted(() => {
      Lazy()
      // console.log(lazyimg.value)
    })

    return {
      placeholderImage,
      lazyimg,
      Lazy
    }
  }
}
</script>

使用懒加载组件的话

<LazyImg :src="item.avatar_url" alt=""></LazyImg>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值