vue3实现图片懒加载

1.新建directives文件夹,里面新建index.ts文件 自定义指令
// 定义自定义指令
const defineDirective = (app: any) => {
  // mylazy指令名称
  app.directive('mylazy', {
    mounted(el: HTMLImageElement, bindings: any) {
      // el表示使用指令的DOM元素
      // bindings表示指令相关的信息是一个对象 如v-lazy="xxx",bindlings即是xxx对应的内容
      // 指令的功能:实现图片的懒加载
      // 1、监听图片是否进入可视区
      const oberver = new IntersectionObserver(([{ isIntersecting }]) => {
        // true;进入可视区域,false:未进入可视区域
        if (isIntersecting) {
          // 1、给图片的src属性赋值图片的地址
          el.src = bindings.value
          // 2、取消图片的监听,默认是会一直监听的,如果不取消。就会一直执行
          oberver.unobserve(el)
          // 3、加载的图片失败了,显示默认的图片地址
          el.onerror = () => {
            el.src = 'https://img-blog.csdnimg.cn/img_convert/32bbcc4fe8a7f33a88ea7579fe052087.png'
          }
        }
      })
      // 监听dom元素
      oberver.observe(el)
    },
  })
}
export default {
  install(app: any) {
    // 自定义指令
    defineDirective(app)
  },
}
main.ts全局引入
import { createApp } from 'vue'
import App from './App.vue'
// 引入自定义指令
import mylazy from '@/directives/index'
createApp(App)
    .use(mylazy)
    .mount('#app')

使用
<template>
  <div class="img-container">
    <img v-mylazy="url" alt="" v-for="url in state.urls" :key="url" />
  </div>
</template>
 
<script lang="ts" setup>
import { ref, reactive } from "vue";
 
// 通过变量方式加载图片,否则图片路径会报错
import img1 from "@/assets/1.webp";
import img2 from "@/assets/2.webp";
import img3 from "@/assets/3.webp";
import img4 from "@/assets/4.webp";
import img5 from "@/assets/5.webp";
import img6 from "@/assets/6.webp";
 
const state = reactive({
  // 直接这样 给图片路径,时会报错的,在代码外附上具体报错,解决办法就是使用import 引入图片作为变量
  // urls: [
  //   "@/assets/1.webp",
  //   "@/assets/2.webp",
  //   "@/assets/3.webp",
  //   "@/assets/4.webp",
  //   "@/assets/5.webp",
  //   "@/assets/6.webp",
  // ],
  urls: [img1, img2, img3, img4, img5, img6],
});
</script>
 
<style scoped lang="scss">
img {
  display: block;
  width: 50vw;
  height: 50vh;
}
</style>
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

A_ugust__

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值