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

Vue3使用hooks函数实现代码复用详解

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

北京

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

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

看不清楚,换张图片

免费获取短信验证码

Vue3使用hooks函数实现代码复用详解

前言

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

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" class="lazy" data-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的方法试一把~~
  • 我们创建一个新的文件,class="lazy" data-src\common-hooks\numberChange.js
  • 把上面的代码,剪切到class="lazy" data-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>

到此这篇关于Vue3使用hooks函数实现代码复用详解的文章就介绍到这了,更多相关Vue3 hooks函数内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

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

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

Vue3使用hooks函数实现代码复用详解

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

下载Word文档

猜你喜欢

C++ 函数继承详解:如何使用虚函数实现代码复用?

函数继承允许派生类继承并重用基类的函数。通过使用虚函数,可以实现代码复用,其中派生类可以覆盖基类的同名函数,并根据调用对象类型动态执行不同的函数版本。C++ 函数继承详解:如何使用虚函数实现代码复用引言函数继承是面向对象编程 (OOP)
C++ 函数继承详解:如何使用虚函数实现代码复用?
2024-05-04

C++ 函数继承详解:如何使用模板继承来实现泛型代码复用?

c++++ 函数继承通过模板继承实现泛型代码复用,允许创建通用函数模板,然后继承更具体的函数,定制不同的数据类型行为。代码示例包括打印容器函数,通过继承定制打印整数和字符串容器。函数继承增强代码复用、可读性、可维护性,以及通过继承类轻松扩展
C++ 函数继承详解:如何使用模板继承来实现泛型代码复用?
2024-05-04

PHP 函数中如何实现代码复用?

php 函数可通过组合代码块实现代码复用。函数定义包含函数名、参数和函数体。调用函数时,使用函数名和参数。命名空间可防止名称冲突。代码复用优点包括模块化、可维护性、代码简洁和效率。PHP 函数中实现代码复用PHP 函数是将代码块组合在一起
PHP 函数中如何实现代码复用?
2024-04-27

详解spring中使用Elasticsearch的代码实现

在使用Elasticsearch之前,先给大家聊一点干货。1. ES和solr都是作为全文搜索引擎出现的。都是基于Lucene的搜索服务器。2. ES不是可靠的存储系统,不是数据库,它有丢数据的风险。3. ES不是实时系统,
2023-05-31

Vue3 中的 readonly 特性及函数使用详解

readonly是Vue3中提供的一个新特性,用于将一个响应式对象变成只读对象,这篇文章主要介绍了Vue3 中的 readonly 特性详解,需要的朋友可以参考下
2023-05-18

C++ 函数继承详解:如何使用继承实现代码解耦和模块化?

函数继承是一种 c++++ 机制,可通过派生新函数从基类覆盖函数,实现代码解耦和模块化。好处包括:代码解耦:分离基类和派生类的代码。模块化:将功能分解为单个模块,提高可重用性。可扩展性:在不修改原有代码的情况下添加新功能。代码重用:可在子类
C++ 函数继承详解:如何使用继承实现代码解耦和模块化?
2024-05-03

PHP函数使用实例代码分析

今天小编给大家分享一下PHP函数使用实例代码分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。PHP检测IP是否内网地址、保
2023-07-05

C++ 函数的泛型编程如何实现代码复用?

c++++ 中的泛型编程使用模板创建可处理任何类型的泛型函数。它提高了代码重用性,减少了错误。示例包括泛型比较函数,可用于比较任意两种类型对象。实战案例,例如排序算法,展示了泛型比较函数如何用于对不同类型数据进行排序。C++ 函数的泛型编程
C++ 函数的泛型编程如何实现代码复用?
2024-04-12

在Golang函数中实现代码复用的有效方法

在 go 中实现代码复用有两种主要方法:函数:将重复任务封装在函数中,并在整个项目中重用。包:将相关的代码组织在包中,允许在程序的不同部分重用代码。在 Go 函数中实现代码复用的有效方法代码复用是在软件开发中重复使用现有代码的技术,旨在提
在Golang函数中实现代码复用的有效方法
2024-04-12

使用Python实现桥接模式的代码详解

Python桥接模式代码详解摘要桥接模式将抽象和实现分离,允许独立修改。在Python中,抽象类定义接口,由具体类实现。接口定义了方法,具体类必须实现。创建抽象类和具体类的实例,并动态改变实现。桥接模式提供了解耦、可扩展性、可读性和可维护性优势。它适用于需要分离抽象和实现,或需要动态更改对象实现的场景。
使用Python实现桥接模式的代码详解
2024-04-02

Vue3使用Swiper实现轮播图示例详解

这篇文章主要为大家介绍了Vue3使用Swiper实现轮播图示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-02-12

codemirror6实现在线代码编辑器使用详解

这篇文章主要为大家介绍了codemirror6实现在线代码编辑器使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-01-08

编程热搜

目录