模块化妙用!用vue3实现一个鼠标追踪器和异步加载组件

简介: 该文章展示了如何使用Vue3的Composition API实现鼠标追踪器功能,并介绍了创建异步加载组件的方法,利用TS泛型增强了组件的灵活性与可维护性。

模块化妙用

周一最近学完 vue3 新特性,就想着用 vue3 来捣鼓点新的小工具。突然想到以前自己遇到的一个问题,想要获取当前鼠标点击的位置,但是以前是直接用原生 js 写的,体验感就没有那么好了,于是乎,今天就用 vue3 来开始我的小工具之旅啦!

在今天的文章中,将带领大家初始化一个 vue3 项目,并且用 vue3 实现一个鼠标追踪器异步加载组件

🎬🎬🎬

一、🖱️鼠标追踪器

1、功能实现

我们先在 vue3 项目下建立一个 ts 文件,这个 ts 文件用来实现鼠标追踪器的功能。具体代码如下:

//引入需要使用的Composition API
import {
    ref, onMounted, onUnmounted } from 'vue'
//实现鼠标追踪器功能
function useMousePosition(){
   

    //初始化x轴和y轴的值
    const x = ref(0)
    const y = ref(0)

    //获取鼠标点击后x轴和y轴的值
    const updateMouse = (e: MouseEvent) => {
   
      x.value = e.pageX
      y.value = e.pageY
    }

    //鼠标点击时执行updateMouse函数
    onMounted(() => {
   
      document.addEventListener('click', updateMouse)
    })

    //鼠标点击结束后对当前点击事件执行销毁操作
    onUnmounted(() => {
   
      document.removeEventListener('click', updateMouse)
    })

    //返回x和y的值
    return {
   x, y}
}

//导出函数
export default useMousePosition

2、给静态页面绑定功能

我们在 vue3 项目下建立一个 .vue 文件,来加载静态组件内容具体代码如下:

<template>
  <div id="app">
    <h1>鼠标追踪器</h1>
    <h1>X:{
  {x}},Y:{
  {y}}</h1>
  </div>
</template>

<script lang="ts">
//引入函数
import useMousePosition from './useMousePosition'

export default{
    
  name: 'App',
  setup(){
    

    //引用函数中返回的值
    const {
     x, y } = useMousePosition()

    //返回值
    return{
    
      x,
      y
    }
  }
};
</script>

<style>
#app {
    
  font-family: Avenir, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
}
</style>

最终我们来看下显示效果:

鼠标追踪器

看完效果,我们来分析下代码。大家可以看到, vue3 中的代码抽离,使得功能实现变得非常方便。我们通过在组件外部再定义一个 ts 文件,来实现具体的功能,而不再将具体的功能放在组件内部来实现。

这样从某种层面上来讲,代码的可扩展性和可维护性都灵活了许多。

二、⚙️异步加载组件

看完鼠标追踪器,我们再来实现一个异步加载组件。

在我们日常的开发中,经常需要用到异步加载组件,而异步加载最常见的需求就是加载loading的状态

加载 loading 的状态其实就是当我们刚开始加载页面时,如果异步请求的内容还没有显示,那就先显示一个 loading 效果让用户先等等,等到异步请求的内容加载出来了,就可以显示具体的效果。

接下来我们就来实现这个功能。

1、功能实现

我们先在 vue3 项目下建立一个 ts 文件,这个 ts 文件用来实现加载异步组件的功能。具体代码如下:

import {
    ref } from 'vue'
import axios from 'axios'

function useURLLoader(url: string){
   
    const result = ref(null)
    const loading = ref(true)
    const loaded = ref(false)
    const error = ref(null)

    axios.get(url).then((rawData) => {
   
        loading.value = false
        loaded.value = true
        result.value = rawData.data
    }).catch(e => {
   
        error.value = e
        loading.value = false
    })

    return{
   
        result,
        loading,
        loaded,
        error
    }
}

export default useURLLoader

实现完功能以后,接下来我们将给静态页面绑定该异步功能。

2、给静态页面绑定功能

这里先给大家介绍一个在线免费API,网址为https://dog.ceo/dog-api/。这个API是一个狗狗API,可以实时获取图片数据。具体使用方式如下:

狗狗API


接下来我们在 vue3 项目下建立一个 .vue 文件,来加载静态组件内容具体代码如下:

<template>
  <div id="app">
    <h1>异步加载组件</h1>
    <button v-if="loading">Loading……</button>
    <img v-if="loaded" :src="result.message">
  </div>
</template>

<script lang="ts">
import useURLLoader from './useUrlLoader'

export default{
    
  name: 'App',
  setup(){
    

    const {
     result, loading, loaded, error } = useURLLoader('https://dog.ceo/api/breeds/image/random')

    return{
    
      result,
      loading,
      loaded,
      error
    }
  }
};
</script>

<style>
#app {
    
  font-family: Avenir, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
}
</style>

最终我们来看下显示效果:

异步加载组件

大家可以看到,当我们刷新时,异步请求的数据还没有加载出来,所以会先显示 Loading ,等到数据加载出来以后,再显示具体的数据,这就是我们经常使用的异步加载组件

3、用泛型改造异步组件功能

大家都知道, vue2 对于 typescript 的支持是非常有限的,因此, vue3 的改造升级后对 ts 有了极大的加持。

在上面的这个例子中,我们已经感受到了 Composition API 的扩展性和维护性,但是呢,不满足于现状,我们还想要再给它来个类型的加持,该怎么做呢?

依据上面的案例,我们继续升级改造。

首先,我们希望 result 可以通过泛型来推断出类型,所以,我们将 ts文件的代码进行以下改造。代码如下:

import {
    ref } from 'vue'
import axios from 'axios'

//泛型改造
function useURLLoader<T>(url: string){
   
    // result的一开始是没有赋予数据类型的,待result赋予数据后,再对其赋予数据类型
    const result = ref<T | null>(null)
    const loading = ref(true)
    const loaded = ref(false)
    const error = ref(null)

    axios.get(url).then((rawData) => {
   
        loading.value = false
        loaded.value = true
        result.value = rawData.data
    }).catch(e => {
   
        error.value = e
        loading.value = false
    })

    return{
   
        result,
        loading,
        loaded,
        error
    }
}

export default useURLLoader

这次我们换一个猫猫的API,来对 .vue 文件进行改造。具体代码如下:

<template>
  <div id="app">
    <h1>异步加载组件</h1>
    <button v-if="loading">Loading……</button>
    <img v-if="loaded" :src="result[0].url">
  </div>
</template>

<script lang="ts">
import {
    watch } from 'vue'
import useURLLoader from './useUrlLoader'

interface CatResult{
   
    id: string;
    url: string;
    width: string;
    height: string;
}

export default{
   
  name: 'App',
  setup(){
   

    const {
    result, loading, loaded, error } = useURLLoader<CatResult[]>('https://api.thecatapi.com/v1/images/search?limit=1')
       watch(result, () => {
   
        if(result.value){
   
            console.log('value', result.value[0].url)
        }
    }) 

    return{
   
      result,
      loading,
      loaded,
      error
    }
  }
};
</script>

<style>
#app {
   
  font-family: Avenir, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
}
</style>

最终浏览器的显示效果如下:

泛型改造异步加载组件

通过代码我们可以发现,用泛型来改造组件,会使得该组件的可扩展性更强ts 这么好的语言谁能不爱呢对吧!

三、📚结束语

到这里,对于 vue3 开发鼠标追踪器和异步加载组件的讲解就结束啦!在这篇文章中,我们学会了用 vue3 的新特性来实现鼠标追踪器和异步加载组件,同时,我们还使用了ts中的泛型和接口,来改造异步加载组件,使其扩展性更强。

vue3 持续学习,更新永不停歇……我们下期见!🥂 🥂 🥂

  • 关注公众号 星期一研究室 ,第一时间关注学习干货,更多精彩专栏待你解锁~

  • 如果这篇文章对你有用,记得一键三连再走哦~

相关文章
|
28天前
|
资源调度 JavaScript 前端开发
创建vue3项目步骤以及安装第三方插件步骤【保姆级教程】
这是一篇关于创建Vue项目的详细指南,涵盖从环境搭建到项目部署的全过程。
136 1
|
2月前
|
JavaScript API 数据处理
vue3使用pinia中的actions,需要调用接口的话
通过上述步骤,您可以在Vue 3中使用Pinia和actions来管理状态并调用API接口。Pinia的简洁设计使得状态管理和异步操作更加直观和易于维护。无论是安装配置、创建Store还是在组件中使用Store,都能轻松实现高效的状态管理和数据处理。
143 3
|
3月前
|
前端开发 JavaScript 测试技术
Vue3中v-model在处理自定义组件双向数据绑定时,如何避免循环引用?
Web 组件化是一种有效的开发方法,可以提高项目的质量、效率和可维护性。在实际项目中,要结合项目的具体情况,合理应用 Web 组件化的理念和技术,实现项目的成功实施和交付。通过不断地探索和实践,将 Web 组件化的优势充分发挥出来,为前端开发领域的发展做出贡献。
73 8
|
3月前
|
存储 JavaScript 数据管理
除了provide/inject,Vue3中还有哪些方式可以避免v-model的循环引用?
需要注意的是,在实际开发中,应根据具体的项目需求和组件结构来选择合适的方式来避免`v-model`的循环引用。同时,要综合考虑代码的可读性、可维护性和性能等因素,以确保系统的稳定和高效运行。
62 1
|
3月前
|
JavaScript
Vue3中使用provide/inject来避免v-model的循环引用
`provide`和`inject`是 Vue 3 中非常有用的特性,在处理一些复杂的组件间通信问题时,可以提供一种灵活的解决方案。通过合理使用它们,可以帮助我们更好地避免`v-model`的循环引用问题,提高代码的质量和可维护性。
79 1
|
2月前
|
JavaScript
vue使用iconfont图标
vue使用iconfont图标
147 1
|
6天前
|
移动开发 JavaScript API
Vue Router 核心原理
Vue Router 是 Vue.js 的官方路由管理器,用于实现单页面应用(SPA)的路由功能。其核心原理包括路由配置、监听浏览器事件和组件渲染等。通过定义路径与组件的映射关系,Vue Router 将用户访问的路径与对应的组件关联,支持哈希和历史模式监听 URL 变化,确保页面导航时正确渲染组件。
|
10天前
|
监控 JavaScript 前端开发
ry-vue-flowable-xg:震撼来袭!这款基于 Vue 和 Flowable 的企业级工程项目管理项目,你绝不能错过
基于 Vue 和 Flowable 的企业级工程项目管理平台,免费开源且高度定制化。它覆盖投标管理、进度控制、财务核算等全流程需求,提供流程设计、部署、监控和任务管理等功能,适用于企业办公、生产制造、金融服务等多个场景,助力企业提升效率与竞争力。
60 12
|
6天前
|
JavaScript 前端开发 开发者
Vue中的class和style绑定
在 Vue 中,class 和 style 绑定是基于数据驱动视图的强大功能。通过 class 绑定,可以动态更新元素的 class 属性,支持对象和数组语法,适用于普通元素和组件。style 绑定则允许以对象或数组形式动态设置内联样式,Vue 会根据数据变化自动更新 DOM。
|
6天前
|
JavaScript 前端开发 数据安全/隐私保护
Vue Router 简介
Vue Router 是 Vue.js 官方的路由管理库,用于构建单页面应用(SPA)。它将不同页面映射到对应组件,支持嵌套路由、路由参数和导航守卫等功能,简化复杂前端应用的开发。主要特性包括路由映射、嵌套路由、路由参数、导航守卫和路由懒加载,提升性能和开发效率。安装命令:`npm install vue-router`。

热门文章

最新文章