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

模块化妙用

用vue3实现一个鼠标追踪器和异步加载组件

  • 一、🖱️鼠标追踪器
    • 1、功能实现
    • 2、给静态页面绑定功能
  • 二、⚙️异步加载组件
    • 1、功能实现
    • 2、给静态页面绑定功能
    • 3、用泛型改造异步组件功能
  • 三、📚结束语

周一最近学完 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.pageXy.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 = falseloaded.value = trueresult.value = rawData.data}).catch(e => {error.value = eloading.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 = falseloaded.value = trueresult.value = rawData.data}).catch(e => {error.value = eloading.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 持续学习,更新永不停歇……我们下期见!🥂 🥂 🥂

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

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/307951.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

leetcode15. 三数之和(三指针)

一:题目 二:思路 1.这里的去重是指的是我们在遍历元素的时候&#xff0c;遇到相同的挨着的相同的元素的时候要跳过 2.对元素进行排序&#xff0c;为了后面的比较 3.我们用的是三个指针&#xff0c;第一个指针i指向第一个元素&#xff0c;第二个指针left指向第二个元素,第三个指…

vue3的传送门teleport究竟有多神奇?suspense发起异步请求有多简约?

一文讲解vue3的Teleport和Suspense一、&#x1f44b;用teleport实现打开模态框操作1、teleport是什么2、实现模态框功能&#xff08;1&#xff09;设置锚点&#xff08;2&#xff09;定义子组件&#xff08;3&#xff09;定义父组件二、&#x1f91a;用Suspense1、Suspense是什…

【BCVP】实现基于 Redis 的消息队列

聆听自己的声音如果自己学不动了&#xff0c;或者感觉没有动力的时候&#xff0c;看看书&#xff0c;听听音乐&#xff0c;跑跑步&#xff0c;休息两天&#xff0c;重新出发&#xff0c;偷懒虽好&#xff0c;可不要贪杯。话说上回书我们说到了&#xff0c;Redis的使用修改《【B…

leetcode18. 四数之和(双指针)

一&#xff1a;题目 二&#xff1a;上码 class Solution { public:vector<vector<int>> fourSum(vector<int>& nums, int target) {vector<vector<int> >ans;vector<int> v;sort(nums.begin(),nums.end());for(int i 0; i < nums…

过去3个多月的1200个小时里,我收获了什么?| 2021年年中总结

&#x1f55b;序言 今年三月初&#xff0c;善后了上学期事情之后&#xff0c;我开始在想&#xff0c;我的未来规划。 身边的好朋友和同学都在筹划着自己的未来&#xff0c;考研的考研&#xff0c;考公的考公。父母和老师们也在劝我说考研&#xff0c;问我考不考研。 依稀记得…

WPF 消息框 TextBox 绑定新数据时让光标和滚动条跳到最下面

WPF 消息框 TextBox 绑定新数据时让光标和滚动条跳到最下面独立观察员 2020 年 9 月 3 日我们在使用 WPF 的 TextBox 作为消息展示框时&#xff0c;如果想在出现滚动条之后&#xff0c;新消息到来时还能够被看到&#xff0c;也就是说让滚动条始终在最下面&#xff0c;或者说光标…

leedcode344. 反转字符串

一:题目 二:上码 class Solution { public:void reverseString(vector<char>& s) {//双指针for(int i 0,j s.size() - 1; i < s.size()/2; i,j--) {swap(s[i],s[j]);}} };

组件库实战 | 用vue3+ts实现全局Header和列表数据渲染ColumnList

用vue3ts实现全局Header和列表数据渲染ColumnList&#x1f5bc;️序言&#x1f4fb;一、ColumnList数据渲染1、设计稿抢先知2、数据构思3、视图数据绑定4、数据传递5、挠头情况☎️二、GlobalHeader全局Header1、设计稿抢先看2、数据构思3、视图数据绑定4、数据传递&#x1f4f…

初识ABP vNext(8):ABP特征管理

点击上方蓝字"小黑在哪里"关注我吧定义特征应用特征用户数量社交登录前言上一篇提到了ABP功能管理&#xff08;特征管理&#xff09;&#xff0c;它来自ABP的FeatureManagement模块&#xff0c;ABP官方文档貌似还没有这个模块的相关说明&#xff0c;但是个人感觉这个…

.NET Core 中导入导出Excel

操作Excel是一个比较常见的业务场景&#xff0c;本篇将使用EPPlus简单演示一个导入导出的示例。EPPlus开源地址&#xff1a;https://github.com/EPPlusSoftware/EPPlus在项目中添加EPPlus组件Install-Package EPPlus导入先准备一个Excel文件&#xff0c;将其内容读取出来&#…

不会webpack的前端可能是捡来的,万字总结webpack的超入门核心知识

一文了解webpack入门核心知识&#x1f3a8;序言&#x1f4c5;一、webpack究竟是什么1、写在前面2、什么是模块打包工具&#xff1f;&#x1f4d0;二、如何用Webpack搭建环境1、安装node2、创建项目3、初始化项目4、安装webpack5、安装具体版本的webpack⚙️三、Webpack的配置文…

剑指 Offer 05. 替换空格(两种做法)

一:题目 二:上码 1:方法一 class Solution { public:string replaceSpace(string s) {string str "";for(int i 0; i < s.size(); i) {if(s[i] ){str "%20";}else{str s[i];}}return str;} };2:方法二&#xff08;双指针&#xff09; class So…

.NET Core 中生成验证码

在开发中&#xff0c;有时候生成验证码的场景目前还是存在的&#xff0c;本篇演示不依赖第三方组件&#xff0c;生成随机验证码图片。先添加验证码接口public interface ICaptcha {/// <summary>/// 生成随机验证码/// </summary>/// <param name"codeLeng…

10分钟手把手教你用Android手撸一个简易的个人记账App

用Android手撸一个简易的个人记账系统⛱️序言&#x1f4cb;一、系统结构设计Design1. 需求分析2. 数据库设计3. 界面设计4. 过程设计&#x1f4d8;二、编码阶段Coding1. 项目结构&#x1f5c2;️&#xff08;1&#xff09;文件目录&#xff08;2&#xff09;AndroidManifest.x…

像素级调整,高效转换——轻松提升你的图片处理体验!

探索更高级的图片处理体验&#xff0c;我们为你带来像素级调整与高效转换的完美结合&#xff01;借助我们的专业工具&#xff0c;轻松调整图片像素&#xff0c;让你在细节处展现无限创意&#xff0c;提升作品质感。 第一步&#xff0c;进入首助编辑高手主页面&#xff0c;可以看…

ABP VNext实践之搭建可用于生产的IdentityServer4

一、前言用了半年多的abp vnext&#xff0c;在开发的效果还是非常的好&#xff0c;可以说节省了很多时间&#xff0c;像事件总线、模块化开发、动态API进行远程调用、自动API控制器等等&#xff0c;一整套的规范&#xff0c;让开发人员更方便的集成&#xff0c;提升效率&#x…

151. 翻转字符串里的单词(思路+详解)

一:题目 二:上码 class Solution { public://利用双指针使除去多余的空格,定义快慢指针&#xff0c;最后满指针指向的位置就是除去冗余空格后的字符串//大小void removespacing(string& s){int slowIndex 0,fastIndex 0;//去掉字符串前面的字符while(s.size() > 0 &a…

一文了解树在前端中的应用,掌握数据结构中树的生命线

一文了解树在前端中的应用&#x1f3d5;️序言&#x1f332;一、树是什么&#xff1f;&#x1f334;二、深/广度优先遍历1、深度优先遍历&#xff08;1&#xff09;定义&#xff08;2&#xff09;口诀&#xff08;3&#xff09;代码实现2、广度优先遍历&#xff08;1&#xff0…

【追加功能】OFFICE插件管理工具重整后再上路,更好用易用。

现在使用OFFICE插件的群体越来越多&#xff0c;在8月份修复过的【OFFICE插件管理工具】&#xff0c;尝试将COM加载项的插件管理进行完善。但仍然有一小部分普通加载项的管理未能加到里面。特别是近期用户反馈到的EasyShu插件不能取消加载问题&#xff08;这个是一个bug&#xf…

剑指 Offer 58 - II. 左旋转字符串

一:题目 二:上码 class Solution { public:string reverseLeftWords(string s, int n) {string str1 s.substr(0,n);//(开始位置&#xff0c;个数)string str2 s.substr(n);return str2str1;} };