每天都要开心()哇:

项目开发过程中,我们会遇到一些情况,就是多个组件都可以重复使用的一部分代码逻辑,功能函数,我们想要复用,这可怎么办呢?

VUE2我们是怎么做的呢?

  • 在vue2 中有一个东西:Mixins 可以实现这个功能
  • mixins就是将这些多个相同的逻辑抽离出来,各个组件只需要引入mixins,就能实现代码复用
  • 弊端一: 会涉及到覆盖的问题
  • 组件的data、methods、filters会覆盖mixins里的同名data、methods、filters
  • 弊端二:隐式传入,变量来源不明确,不利于阅读,使代码变得难以维护

VUE3中我们怎么处理复用代码逻辑的封装呢?

  • Vue3中我们可以: 自定义Hook
  • Vue3 的 hook函数 相当于 vue2 的 mixin, 但是: hooks 是函数
  • Vue3 的 hook函数 可以帮助我们提高代码的复用性, 让我们能在不同的组件中都利用 hooks 函数

说那么多,不如直接上代码来看差异

  • 先来一段我们的一把梭代码,代码没有复用,全都放到当前组件
<template>
<img alt="Vue logo" src="./assets/logo.png" />
<div>
VUE3中的HOOKS
</div>
<button @click="setNumber">点击此按钮,调用setNumber函数,数字会+1:{{myNumber}}</button>
<button @click="a++">点击此按钮,数字会+1:{{a}}</button>
<button @click="b--">点击此按钮,数字会-1:{{b}}</button>
</template>
<script>
import { reactive,ref,computed,watch,watchEffect } from "vue";
export default {
setup(){
const myNumber = ref(0)
const a = ref(0)
const b = ref(0)
const setNumber = ()=>{
myNumber.value = myNumber.value+1;
}
watch([a,b],([newA,newB],[oldA,oldB])=>{
console.log('newA,oldA:')
console.log(newA,oldA)
console.log('newA,oldB:')
console.log(newA,oldB)
})
return{
myNumber,
a,
b,
setNumber
}
}
}
</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; }
button{
display: block;
margin: 0 auto;
}
</style>
  • 执行代码看一下下哇~~

  • 上面是原始的写法,如果这里面好几个变量我们需要复用怎么办呢?比如说这几个变量,函数,我们需要在其他函数里也用到,我们要怎么办呢??
  • 下面我们就开始采用hook的方法试一把~~
  • 我们创建一个新的文件,src\common-hooks\numberChange.js
  • 把上面的代码,剪切到src\common-hooks\numberChange.js,然后用这个套起来:export const useNumber =() =>{}
import { ref,watch } from "vue";
export const useNumber =() =>{
const myNumber = ref(0)
const a = ref(0)
const b = ref(0)
const setNumber = ()=>{
myNumber.value = myNumber.value+1;
}
watch([a,b],([newA,newB],[oldA,oldB])=>{
console.log('newA,oldA:')
console.log(newA,oldA)
console.log('newA,oldB:')
console.log(newA,oldB)
})
return{
myNumber,
a,
b,
setNumber
}
}

  • 改写一下我们的模板代码里的script
<script>
import { useNumber } from "./common-hooks/numberChange";
export default {
setup() {
const { myNumber, a, b, setNumber } = useNumber();
return { myNumber, a, b, setNumber };
},
};
</script>
  • 哇哦,(),是不是有点开心,代码看起来是不是感觉,神清气爽了???
  • 然后测试一下我们的代码吧~~~
  • 不放图了哦,依然正常运行的哇~~
  • 今天就写到这里啦~小伙伴们,( ̄ω ̄( ̄ω ̄〃 ( ̄ω ̄〃)ゝ我们明天再见啦~~
  • 大家要天天()哦

欢迎大家指出文章需要改正之处~

学无止境,合作共赢

欢迎路过的小哥哥小姐姐们提出更好的意见哇~~

最新文章

  1. java.net.SocketException: Connection reset
  2. 应用程序框架实战十八:DDD分层架构之聚合
  3. emmet插件学习,练习中遇到一些问题
  4. 在SQL Server中添加供应用程序使用的帐号
  5. 第三次作业——个人作业,k米案例分析
  6. phpcms模块开发简易教程
  7. js sleep效果
  8. iOS常用动画代码
  9. Android中9patch图片格式(xx.9.png)介绍与制作详解
  10. String的点点滴滴
  11. Scut AccountServer
  12. 使用InternetReadFile时要注意读取完整数据
  13. lxd-启动篇分析
  14. “大话架构”阿里架构师分享的Java程序员需要突破的技术要点
  15. softmax in pytorch
  16. java中Map集合的常用方法 (转)
  17. thinkphp 5 使用oss
  18. CodeBlock 快捷键大全
  19. AJPFX技术分析入门
  20. linux磁盘相关命令

热门文章

  1. MySQL索引报错
  2. c++ 模板 指针类型偏特化
  3. Java多线程-ThreadPool线程池(三)
  4. javascript异步编程,promise概念
  5. 开箱即用 yyg-cli(脚手架工具):快速创建 vue3 组件库和vue3 全家桶项目
  6. JS 学习笔记(一)常用的字符串去重方法
  7. 带你从0到1开发AI图像分类应用
  8. 如何使用webgl(three.js)实现3D储能,3D储能站,3D智慧储能、储能柜的三维可视化解决方案——第十七课
  9. 【题解】CF1722F L-shapes
  10. xshell登陆,查看中文日志出现乱码