前端vue3实现图片懒加载的完整步骤记录

 更新时间:2025年06月24日 09:29:15   作者:夏霞.  
在现代前端开发中懒加载是一种提高应用性能和用户体验的重要技术,尤其是在处理较大图片或长列表数据时,这篇文章主要介绍了前端vue3实现图片懒加载的相关资料,需要的朋友可以参考下

场景和指令用法

场景:电商网站的首页通常会很长,用户不一定能访问到页面靠下面的图片,这类图片通过懒加载优化手段可以做到只有进入视口区域才发送图片请求

核心原理:图片进入视口才发送资源请求

首先:我们需要定义一个全局的指令,vue3官方的实现方法是这样的

第一步:熟悉指令语法

并且:还需要用到一个钩子函数

第二步:判断图片是否进入视口

我们可以使用useIntersectionObserver这个函数

以下是官方示例的使用方法:

<script setup lang="ts">
import { useIntersectionObserver } from '@vueuse/core'

const { stop } = useIntersectionObserver(
  target,
  ([entry], observerElement) => {
    targetIsVisible.value = entry?.isIntersecting || false
  },
)
</script>

target:需要监听的元素

isIntersecting:是一个布尔值 监听是否进入可视区

以下是完整代码实现

main.js

import { useIntersectionObserver } from '@vueuse/core'
const app = createApp(App)
// 定义全局指令
app.directive('img-lazy', {
  mounted(el, binding) {
    // el: 指令绑定的元素
    // binding: binding.value 指令的绑定值 图片url
    console.log(el, binding.value);
    useIntersectionObserver(
        el, // 监听的元素
        ([{ isIntersecting }]) => { 
            // isIntersecting是一个布尔值 监听是否进入可视区
            console.log(isIntersecting);       
            if (isIntersecting) {
                // 图片进入可视区 设置图片的src
                el.src = binding.value
            }
        }
    )
  }
})

在需要懒加载的图片标签里使用这个即可

<img v-img-lazy="item.picture"  alt="" />

页面效果

由上图可以看出在刚进入页面时需要懒加载的图片没有加载出来

由上图可以看出当页面滑动到人气推荐时url全部都加载出来了

回顾核心步骤代码

================================补档优化==================================

问题1:逻辑书写位置不合理问:懒加载指令的逻辑直接写到入口文件中,合理吗?

答:不合理,入口文件通常只做一些初始化的事情,不该包含太多的逻辑代码,可以通过插件的方法把懒加载指令封装为插件,main.js入口文件只需要负责注册插件即可

代码实现:

插件代码

// 定义懒加载指令
import { useIntersectionObserver } from '@vueuse/core'

export const lazyPlugin = {
    install(app) {
        app.directive('img-lazy', {
            mounted(el, binding) {
                // el: 指令绑定的元素
                // binding: binding.value 指令的绑定值 图片url
                console.log(el, binding.value);
                useIntersectionObserver(
                    el, // 监听的元素
                    ([{ isIntersecting }]) => {
                        // isIntersecting是一个布尔值 监听是否进入可视区
                        console.log(isIntersecting);
                        if (isIntersecting) {
                            // 图片进入可视区 设置图片的src
                            el.src = binding.value
                        }
                    }
                )
            }
        })
    }
}

main.js

// 引入懒加载指令并且注册
import { lazyPlugin } from '@/directives'
app.use(lazyPlugin)

问题2:重复监听问题uselntersectionObserver对于元素的监听是一直存在的,除非手动停止监听,存在内存浪费
解决思路:在监听的图片第一次完成加载之后就停止监听

代码实现:

// 定义懒加载指令
import { useIntersectionObserver } from '@vueuse/core'

export const lazyPlugin = {
    install(app) {
        app.directive('img-lazy', {
            mounted(el, binding) {
                // el: 指令绑定的元素
                // binding: binding.value 指令的绑定值 图片url
                console.log(el, binding.value);
               const {stop} =  useIntersectionObserver(
                    el, // 监听的元素
                    ([{ isIntersecting }]) => {
                        // isIntersecting是一个布尔值 监听是否进入可视区
                        console.log(isIntersecting);
                        if (isIntersecting) {
                            // 图片进入可视区 设置图片的src
                            el.src = binding.value
                            stop()
                        }
                    }
                )
            }
        })
    }
}

总结 

到此这篇关于前端vue3实现图片懒加载的文章就介绍到这了,更多相关前端vue3图片懒加载内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 详细讲一讲vue3下会造成响应式丢失的情况

    详细讲一讲vue3下会造成响应式丢失的情况

    vue3开发过程中,绑定的响应式数据失去了响应式,如何解决问题呢,下面这篇文章主要给大家介绍了关于vue3下会造成响应式丢失的情况,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-06-06
  • VUE项目自动检测服务端是否发布了新版本

    VUE项目自动检测服务端是否发布了新版本

    本文主要介绍了VUE项目自动检测服务端是否发布了新版本,通过轮询方式检测Vue项目新版本并提示用户刷新页面,具有一定的参考价值,感兴趣的可以了解一下
    2025-01-01
  • vue+vuex+axio从后台获取数据存入vuex实现组件之间共享数据

    vue+vuex+axio从后台获取数据存入vuex实现组件之间共享数据

    这篇文章主要介绍了vue+vuex+axio从后台获取数据存入vuex,组件之间共享数据,非常具有实用价值,需要的朋友可以参考下
    2017-04-04
  • vue-cli 组件的导入与使用教程详解

    vue-cli 组件的导入与使用教程详解

    这篇文章主要介绍了vue-cli--组件的导入与使用详解,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2018-04-04
  • Vue的样式绑定详解

    Vue的样式绑定详解

    这篇文章主要为大家详细介绍了Vue的样式绑定,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-02-02
  • vuejs点击class变化的实例

    vuejs点击class变化的实例

    今天小编就为大家分享一篇vuejs点击class变化的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-09-09
  • Vue 实现前进刷新后退不刷新的效果

    Vue 实现前进刷新后退不刷新的效果

    这篇文章主要介绍了Vue 实现前进刷新后退不刷新的效果,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-06-06
  • vue在路由中验证token是否存在的简单实现

    vue在路由中验证token是否存在的简单实现

    今天小编就为大家分享一篇vue在路由中验证token是否存在的简单实现,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-11-11
  • vue 实现图片懒加载功能

    vue 实现图片懒加载功能

    这篇文章主要介绍了vue 实现图片懒加载功能的方法,帮助大家更好的理解和使用vue,感兴趣的朋友可以了解下
    2020-12-12
  • 详解vue中使用vue-quill-editor富文本小结(图片上传)

    详解vue中使用vue-quill-editor富文本小结(图片上传)

    这篇文章主要介绍了详解vue中使用vue-quill-editor富文本小结(图片上传),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04

最新评论