我的编程空间,编程开发者的网络收藏夹
学习永远不晚

vue3中使用@vueuse/core中的图片懒加载案例详解

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

vue3中使用@vueuse/core中的图片懒加载案例详解

点击进入vueuse官网

1、首先安装

npm i @vueuse/core

2、新建一个helloworld.js文件,内容如下:

import { useIntersectionObserver } from '@vueuse/core'
import {ref} from "vue";

export const useLazyData = (apiFn) => {
    const result = ref([])
    const target = ref(null)
    // stop 停止观察
    const { stop } = useIntersectionObserver(
        // 监听的目标元素
        target,
        ([{ isIntersecting }], observerElement) => {
            // isIntersecting 是否进入可视区
            if (isIntersecting) {
                stop()
                // 调用API函数获取数据
                 const aa  = apiFn()
                console.log('aa', aa)
                result.value = aa
                // // 调用API函数获取数据  
		        // apiFn().then(data => {
		        //   result.value = data.result
		        // })
            }
        },
        // 配置选项,相交的比例大于0就触发
        {
            threshold: 0
        }
    )
    return { result, target }
}

3、再app.vue中导包并使用

<template>
<div>
  <div class="up"></div>
  <div ref="target" :style="{backgroundColor: bgc}" class="down"></div>
</div>
</template>

<script setup>
import {useLazyData} from "@/helloworld";
import {nextTick, onMounted, ref} from "vue";
let bgc = ref('#000')

// 发送请求的函数
// export const findNew = () => {
//    return request('/home/new', 'get')
// }
const qingqiuhanshu = () => {
  // 模仿请求
  return '#1DC779'
}
const { target, result } = useLazyData(qingqiuhanshu)
bgc = result

</script>

<style lang="less" scoped>
.up{
  height: 100vh;
  margin-bottom: 20px;
  background-color: pink;
}
.down{
  height: 50px;
  background-color: deeppink;
}
</style>

4、观察效果:会发现当滚轮滑到底部时右边控制台会打印,没滑动到底部则不会打印,同时显示出下边的颜色

在这里插入图片描述

到此这篇关于vue3中使用@vueuse/core中的图片懒加载案例详解的文章就介绍到这了,更多相关vue3图片懒加载内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

vue3中使用@vueuse/core中的图片懒加载案例详解

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

vue3中使用@vueuse/core中的图片懒加载案例详解

这篇文章主要介绍了vue3中使用@vueuse/core中的图片懒加载案例,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下
2023-03-19

vue3怎么使用@vueuse/core中的图片懒加载

这篇文章主要介绍“vue3怎么使用@vueuse/core中的图片懒加载”,在日常操作中,相信很多人在vue3怎么使用@vueuse/core中的图片懒加载问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue
2023-07-05

vue3 图片懒加载的两种方式、IntersectionObserver和useIntersectionObserver实例详解

这篇文章主要介绍了vue3 图片懒加载的两种方式、IntersectionObserver和useIntersectionObserver实例详解,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下
2023-03-19

flutter中的资源和图片加载示例详解

这篇文章主要为大家介绍了flutter中的资源和图片加载示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-12-29

Android中使用二级缓存、异步加载批量加载图片完整案例

一、问题描述 Android应用中经常涉及从网络中加载大量图片,为提升加载速度和效率,减少网络流量都会采用二级缓存和异步加载机制,所谓二级缓存就是通过先从内存中获取、再从文件中获取,最后才会访问网络。内存缓存(一级)本质上是Map集合以ke
2022-06-06

编程热搜

目录