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

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 详解

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

API设计:从基础到最佳实践

1*vWvkkgG6uvgmJT8GkId98A.png 在这次深入探讨中,我们将深入了解API设计,从基础知识开始,逐步进阶到定义出色API的最佳实践。 作为开发者,你可能对许多这些概念很熟悉,但我将提供详细的解释,以加深你的理解…...

每日汇评:由于中东危机削弱了风险偏好,欧元将在1.0900附近波动

随着中东危机的加深,欧元兑美元面临大幅抛售; 由于高通胀,欧洲央行决策者推迟了市场对早期降息的预期; 市场将受到周三公布的美国零售销售数据的影响; 持续的中东紧张局势增强了对避险资产的吸引力,而风险感…...

算法每日一题:删除子串后的字符串最小长度 | 栈 | 字符串

大家好,我是星恒 今天给大家带来的是一道另类的栈的应用 话不多说,我们直接来体验 题目:leetcode 2696 给你一个仅由 大写 英文字符组成的字符串 s 。你可以对此字符串执行一些操作,在每一步操作中,你可以从 s 中删除 …...

SpringFramework实战指南(一)

SpringFramework实战指南(一) 一、技术体系结构1.1 总体技术体系1.2 框架概念和理解 一、技术体系结构 1.1 总体技术体系 单一架构 一个项目,一个工程,导出为一个war包,在一个Tomcat上运行。也叫all in one。 单一架…...

AtCoder ABC198

本期F为群论题,很有难度。 C - Compass Walking 为了避免精度问题,采用二分推算。但是要小心结果为1的地方。 R 2 ∗ k 2 ≥ x 2 y 2 R^2*k^2\geq x^2y^2 R2∗k2≥x2y2 # -*- coding: utf-8 -*- # time : 2023/6/2 13:30 # file : atcoder.…...

phpinfo和php -m 加载的php.ini不一致

目的: 将phpinfo在web中展示的php.ini和在命令行中展示的php.ini加载路径设置一致。 原本的php.ini加载路劲是: /usr/local/lib/php.ini 解决思路: (1)which php 查看服务器加载的php的位置,这里原来是&a…...

121.买卖股票的最佳时机 122.买卖股票的最佳时机II

121.买卖股票的最佳时机 122.买卖股票的最佳时机II 121.买卖股票的最佳时机 力扣题目链接(opens new window) 给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。 你只能选择 某一天 买入这只股票,并选择在 未来的某一…...

Spring Boot整理-Spring Boot是什么?

Spring Boot 是一个开源的 Java 基础框架,它旨在简化基于 Spring 的应用开发。其核心特点在于“约定优于配置”的设计哲学,意味着它提供了一系列默认配置,从而帮助开发者更快地启动和运行新的 Spring 应用。Spring Boot 的主要特点包括: 自动配置:Spring Boot 可以根据项目…...

【pytorch】Pytorch 中的 grid 与 各种变换

Pytorch 中的 grid 与 各种变换 数学原理 **单应性(Homography) : 也就是透视变换。**单应性最初用来研究欧几里得几何中的透视和投影,而单应性一词,从词源学上来说,大致意思是“相似的绘图”。单应性的概念被引入来…...

【Linux】线程池实现

📗线程池实现(单例模式) 1️⃣线程池概念2️⃣线程池代码样例3️⃣部分问题与细节🔸类成员函数参数列表中隐含的this指针🔸单例模式🔸一个失误导致的bug 4️⃣调用线程池完成任务 1️⃣线程池概念 线程池是…...

使用Python批量上传本地maven库到nexus

背景:外包类项目开发时是调用的公司maven仓库进行开发,交付后需要将maven仓库转移到客户环境。 原理:1、打开idea运行源代码,将maven包下载到本地仓库, 2、下载包所在目录中执行脚本将本地仓库的maven包上传到客户nex…...

【Unity实战100例】Unity对Ini格式的配置文件管理和读写

目录 一.编写ini格式配置文件 二.读取解析ini文件 三.调用属性 INI 文件以文本形式存储,易于阅读和编辑。这种人可读的格式使得调整配置参数变得更加直观,不需要专门的工具。 INI 文件是一种轻量级的配置文件格式,不需要复杂的解析器或库。它的结构相对简单,适用于小到...

k8s存储卷和数据卷下

静态pv和pvc 运维负责pv:创建号持久化存储卷,申明好读写和挂载类型,以及可以提供的存储空间 Pvc开发做,要和开发沟通好,你期望的读写和挂载类型,以及存储空间 当我发布vc之后可以生成pv,还可以在…...

SQL Server 配置远程连接

Windows 安装好 SQL Server 的 SSMS,打开SSMS配置远程连接 找到 配置管理器 启用 TCP/IP 打开防火墙设置 新建入站规则 端口TCP - 特定本地端口 (1433)允许连接下一步名称完成 重启 SQL Server 服务...

vscode(visual studio code) 免密登陆服务器

1.生成密钥 首先,在本地,打开命令输入框: WinR–>弹出输入框,输入cmd,打开命令框。 然后,在命令框,输入 ssh-keygen -t rsa -C "love"按两次回车键,问你是否重写,选择…...

[redis] redis主从复制,哨兵模式和集群

一、redis的高可用 1.1 redis高可用的概念 在web服务器中,高可用是指服务器可以正常访问的时间,衡量的标准是在多长时间内可以提供正常服务(99.9%、99.99%、99.999%等等)。 高可用的计算公式是1-(宕机时间)/(宕机时…...

debian12部署Gitea服务

首先安装git、wget、sqlite,然后进行用户和组的相关设置 sudo apt install -y git wget sqlite3 新增一个git用户与一个git组 sudo adduser --system --group --disabled-password --shell /bin/bash --home /home/git --gecos Git Version Control git 给git用户设…...

js动态设置关键侦@keyframes

js动态设置关键侦keyframes 1.前置知识 关键侦keyframes规则通过在动画序列中定义关键侦的样式来控制CSS动画序列的中间步骤 keyframes slidein {from {transform: translateX(0%);}to {transform: translateX(100%);} } // from 等价于 0%;to 等价与 100% // 或…...

【WPF.NET开发】流文档

本文内容 什么是流文档?流文档类型创建流内容与流相关的类内容架构自定义文本 流文档旨在优化查看和可读性。 流文档根据运行时变量(例如,窗口大小、设备分辨率和可选的用户首选项)来动态调整和重新排列内容,而不是设…...

【网络】每天掌握一个Linux命令 - iftop

在Linux系统中,iftop是网络管理的得力助手,能实时监控网络流量、连接情况等,帮助排查网络异常。接下来从多方面详细介绍它。 目录 【网络】每天掌握一个Linux命令 - iftop工具概述安装方式核心功能基础用法进阶操作实战案例面试题场景生产场景…...

docker详细操作--未完待续

docker介绍 docker官网: Docker:加速容器应用程序开发 harbor官网:Harbor - Harbor 中文 使用docker加速器: Docker镜像极速下载服务 - 毫秒镜像 是什么 Docker 是一种开源的容器化平台,用于将应用程序及其依赖项(如库、运行时环…...

如何在看板中体现优先级变化

在看板中有效体现优先级变化的关键措施包括:采用颜色或标签标识优先级、设置任务排序规则、使用独立的优先级列或泳道、结合自动化规则同步优先级变化、建立定期的优先级审查流程。其中,设置任务排序规则尤其重要,因为它让看板视觉上直观地体…...

【网络安全产品大调研系列】2. 体验漏洞扫描

前言 2023 年漏洞扫描服务市场规模预计为 3.06(十亿美元)。漏洞扫描服务市场行业预计将从 2024 年的 3.48(十亿美元)增长到 2032 年的 9.54(十亿美元)。预测期内漏洞扫描服务市场 CAGR(增长率&…...

剑指offer20_链表中环的入口节点

链表中环的入口节点 给定一个链表,若其中包含环,则输出环的入口节点。 若其中不包含环,则输出null。 数据范围 节点 val 值取值范围 [ 1 , 1000 ] [1,1000] [1,1000]。 节点 val 值各不相同。 链表长度 [ 0 , 500 ] [0,500] [0,500]。 …...

零基础设计模式——行为型模式 - 责任链模式

第四部分:行为型模式 - 责任链模式 (Chain of Responsibility Pattern) 欢迎来到行为型模式的学习!行为型模式关注对象之间的职责分配、算法封装和对象间的交互。我们将学习的第一个行为型模式是责任链模式。 核心思想:使多个对象都有机会处…...

算法岗面试经验分享-大模型篇

文章目录 A 基础语言模型A.1 TransformerA.2 Bert B 大语言模型结构B.1 GPTB.2 LLamaB.3 ChatGLMB.4 Qwen C 大语言模型微调C.1 Fine-tuningC.2 Adapter-tuningC.3 Prefix-tuningC.4 P-tuningC.5 LoRA A 基础语言模型 A.1 Transformer (1)资源 论文&a…...

AI病理诊断七剑下天山,医疗未来触手可及

一、病理诊断困局:刀尖上的医学艺术 1.1 金标准背后的隐痛 病理诊断被誉为"诊断的诊断",医生需通过显微镜观察组织切片,在细胞迷宫中捕捉癌变信号。某省病理质控报告显示,基层医院误诊率达12%-15%,专家会诊…...

算法:模拟

1.替换所有的问号 1576. 替换所有的问号 - 力扣(LeetCode) ​遍历字符串​:通过外层循环逐一检查每个字符。​遇到 ? 时处理​: 内层循环遍历小写字母(a 到 z)。对每个字母检查是否满足: ​与…...

三分算法与DeepSeek辅助证明是单峰函数

前置 单峰函数有唯一的最大值,最大值左侧的数值严格单调递增,最大值右侧的数值严格单调递减。 单谷函数有唯一的最小值,最小值左侧的数值严格单调递减,最小值右侧的数值严格单调递增。 三分的本质 三分和二分一样都是通过不断缩…...