Vue 3 Composition API 详解

2024-01-13 11:20

本文主要是介绍Vue 3 Composition API 详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、引言

在Vue 3中,引入了一个新的Composition API,旨在提供一种更灵活和可重用的方式来组织组件代码。Composition API基于函数式编程思想,允许开发者将逻辑和状态管理逻辑分离,使代码更加清晰和可维护。

二、Composition API的核心概念

  1. 响应式数据

在Vue 3中,响应式数据是组件状态的重要组成部分。通过使用reactive函数,你可以创建响应式对象,其属性会随着对象属性的改变而自动更新。这对于构建状态管理非常有用。

	import { reactive } from 'vue';  const state = reactive({  count: 0,  name: 'Vue 3'  });

在Vue 3中,响应式数据是通过reactive函数创建的。reactive函数返回一个响应式对象,该对象的属性值会自动更新并反映其依赖项的变化。这意味着当对象的属性值发生变化时,任何依赖于这些属性的部分都将自动更新。

  1. Refs与Reactive

在Vue 3中,你可以使用ref来包装响应式数据。ref用于创建响应式引用,你可以通过.value属性来访问它的值。相比之下,reactive用于创建响应式对象。

	import { ref } from 'vue';  const count = ref(0); // 创建一个响应式引用  console.log(count.value); // 访问值

使用ref函数可以创建响应式引用,这对于包装单个值非常有用。通过.value属性可以访问或修改引用的值。与reactive不同,ref更加适合包装简单类型的值(如数字、字符串、布尔值等)。

  1. 计算属性

在Vue 3中,计算属性通过computed函数定义。计算属性是基于其依赖项进行缓存的,只有在其依赖项发生变化时才会重新计算。这可以避免不必要的计算和性能开销。

	import { reactive, computed } from 'vue';  const state = reactive({  firstName: 'Foo',  lastName: 'Bar'  });  const fullName = computed(() => `${state.firstName} ${state.lastName}`); // 计算属性

计算属性是在Vue 3中用于执行更复杂的数据操作的强大工具。它们基于其依赖项进行缓存,这意味着只有在依赖项发生变化时才会重新计算属性值。这有助于提高性能,因为不必要的计算和重复操作被避免了。计算属性可以通过computed函数定义,并返回一个函数,该函数根据其依赖项返回相应的值。在上面的例子中,我们定义了一个计算属性fullName,它将返回一个拼接了firstNamelastName的值。只有当这些依赖项中的任何一个发生更改时,fullName才会重新计算。

  1. watchEffect

watchEffect函数允许你在特定依赖项更改时执行副作用操作。它类似于Vue 2中的watch,但更加灵活。你可以在组件的setup函数中使用watchEffect来观察和响应数据变化。

	import { watchEffect } from 'vue';  import { useState } from 'vue';  export default {  setup() {  const state = reactive({ name: 'Vue 3' });  const [count, setCount] = useState(0);  watchEffect(() => {  console.log(state.name); // 观察state.name的变化并执行副作用操作  });  return { count }; // 返回响应式数据供模板使用  }  };

watchEffect函数在Vue 3中提供了一种观察和响应数据变化的方式。它类似于Vue 2中的watch,但更加灵活和强大。你可以在组件的setup函数中使用watchEffect来注册副作用操作,这些操作将在特定依赖项发生变化时执行。在上面的例子中,我们使用watchEffect来观察state.name`的变化,并在控制台中打印出新的值。通过这种方式,你可以在数据变化时执行异步或长时间运行的操作,例如API调用、动画处理等。

三、Composition API的使用场景

  1. 重用逻辑: 使用reactiveref,你可以轻松地创建可重用的状态片段。
  2. 逻辑复用computed属性允许你根据其他响应式数据创建新的响应式数据。
  3. 副作用操作watchEffect允许你在特定依赖项更改时执行异步或长时间运行的操作。

四、Composition API的最佳实践

  1. 避免全局状态管理: Composition API鼓励将状态局部化,避免全局状态管理。
  2. 使用 setup 函数: 在Vue 3中,每个组件都需要一个setup函数,这是使用Composition API的主要场所。
  3. 合理使用 Ref 和响应式对象: 根据需要选择使用ref还是响应式对象来存储数据。
  4. 利用 Composition API 的优势: 如上文所述,利用好reactiverefcomputedwatchEffect来优化你的组件代码结构。

五、与 Options API 的比较和迁移策略

  1. Options API的限制: 在Vue 3中,Options API(即Vue 2中的声明式渲染方式)在某些情况下可能显得笨重和不够灵活。
  2. 迁移策略: 逐步迁移到Composition API,同时保持与Options API的兼容性,以便于平滑过渡。

六、总结

Vue 3的Composition API为开发者提供了一种新的方式来组织和重用组件逻辑。通过理解和掌握Composition API的核心概念、使用场景和最佳实践,开发者可以构建出更加清晰、可维护和高效的Vue应用程序。尽管Migration API提供了一种向Composition API过渡的方式,但开发者仍需注意两者的区别和最佳实践,以确保应用程序的稳定性和性能。

这篇关于Vue 3 Composition API 详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/601290

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

【 html+css 绚丽Loading 】000046 三才归元阵

前言:哈喽,大家好,今天给大家分享html+css 绚丽Loading!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕 目录 📚一、效果📚二、信息💡1.简介:💡2.外观描述:💡3.使用方式:💡4.战斗方式:💡5.提升:💡6.传说: 📚三、源代码,上代码,可以直接复制使用🎥效果🗂️目录✍️

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

Vue3项目开发——新闻发布管理系统(六)

文章目录 八、首页设计开发1、页面设计2、登录访问拦截实现3、用户基本信息显示①封装用户基本信息获取接口②用户基本信息存储③用户基本信息调用④用户基本信息动态渲染 4、退出功能实现①注册点击事件②添加退出功能③数据清理 5、代码下载 八、首页设计开发 登录成功后,系统就进入了首页。接下来,也就进行首页的开发了。 1、页面设计 系统页面主要分为三部分,左侧为系统的菜单栏,右侧

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP