当前位置: 首页 > news >正文

制作h5的免费软件企业网站seo参考文献

制作h5的免费软件,企业网站seo参考文献,单页网站与传统网站的区别,wordpress手机双模板下载用vue3实现一个鼠标追踪器和异步加载组件一、#x1f5b1;️鼠标追踪器1、功能实现2、给静态页面绑定功能二、⚙️异步加载组件1、功能实现2、给静态页面绑定功能3、用泛型改造异步组件功能三、#x1f4da;结束语周一最近学完 vue3 新特性#xff0c;就想着用 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 useMousePosition2、给静态页面绑定功能 我们在 vue3 项目下建立一个 .vue 文件来加载静态组件内容。具体代码如下 templatediv idapph1鼠标追踪器/h1h1X:{{x}},Y:{{y}}/h1/div /templatescript langts //引入函数 import useMousePosition from ./useMousePositionexport default{name: App,setup(){//引用函数中返回的值const { x, y } useMousePosition()//返回值return{x,y}} }; /scriptstyle #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 axiosfunction 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可以实时获取图片数据。具体使用方式如下 接下来我们在 vue3 项目下建立一个 .vue 文件来加载静态组件内容。具体代码如下 templatediv idapph1异步加载组件/h1button v-ifloadingLoading……/buttonimg v-ifloaded :srcresult.message/div /templatescript langts import useURLLoader from ./useUrlLoaderexport default{name: App,setup(){const { result, loading, loaded, error } useURLLoader(https://dog.ceo/api/breeds/image/random)return{result,loading,loaded,error}} }; /scriptstyle #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 useURLLoaderT(url: string){// result的一开始是没有赋予数据类型的待result赋予数据后再对其赋予数据类型const result refT | 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 文件进行改造。具体代码如下 templatediv idapph1异步加载组件/h1button v-ifloadingLoading……/buttonimg v-ifloaded :srcresult[0].url/div /templatescript langts import { watch } from vue import useURLLoader from ./useUrlLoaderinterface CatResult{id: string;url: string;width: string;height: string; }export default{name: App,setup(){const { result, loading, loaded, error } useURLLoaderCatResult[](https://api.thecatapi.com/v1/images/search?limit1)watch(result, () {if(result.value){console.log(value, result.value[0].url)}}) return{result,loading,loaded,error}} }; /scriptstyle #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.yutouwan.com/news/224827/

相关文章:

  • 中国站长之家二级网站建设要求
  • 网站的劣势科技展厅设计方案
  • 网站开发用什么语言好广东东莞发布最新消息
  • 绍兴网站建设公司电话中国空间站建造历程
  • 备案域名网站大全crm客户关系管理系统登录
  • 蚌埠建设网站公司查询行业信息的网站
  • 广元北京网站建设做网站违反广告法
  • 你了解网站建设吗 软文案例公司官网怎么做的
  • 成都微信网站建设报价网站 默认首页
  • 上海地区网站建设网站域名 空间
  • 浙江绿建设计院网站wordpress循环所有文脏
  • 价格对比网站开发企业网站建设合同范本
  • 网站建设行业数据站群推广
  • 公司网站域名注册流程怎样建设卡盟网站
  • 怎样做才能提升自己的网站网站后台添加投票系统
  • html网站设计范例网店运营推广高级实训教程
  • 网站排名哪家好河源市连平县建设局网站
  • 模板网站外贸建站网络平台推广运营培训
  • tiktok官方网站入口电子商务网站建设的需求
  • 云南专业建网站免费的网站推荐下载
  • 昆山住房与城乡建设局网站天津网站优化公司价格
  • 公民道德建设网站中国网络营销传播网
  • 做网站的一个黑点符号做网站要用什么语言
  • 徐州制作网站的公司有哪些公主坟网站建设
  • 自助网站建设开发asp.net网站开发试题
  • 手机网站产品展示模板网站建设从化
  • c#网站开发技术wordpress默认排序
  • 医院网站后台管理系统登录网站关键词优化应该怎么做
  • 网页设计和网站开发有什么区别电商网站建设与运营方向就业前景
  • 芜湖门户网站建设多少钱如何提高权重