场景和指令用法
场景:电商网站的首页通常会很长,用户不一定能访问到页面靠下面的图片,这类图片通过懒加载优化手段可以做到只有进入视口区域才发送图片请求
核心原理:图片进入视口才发送资源请求
首先:我们需要定义一个全局的指令,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:是一个布尔值 监听是否进入可视区
以下是完整代码实现
- 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
- }
- }
- )
- }
- })
- }
- }
复制代码- // 引入懒加载指令并且注册
- 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图片懒加载内容请搜索晓枫资讯以前的文章或继续浏览下面的相关文章希望大家以后多多支持晓枫资讯!
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |