Vue 3 中的 Composition API 详解

news/2024/7/9 23:35:27 标签: vue

Vue.js,作为前端领域流行的框架之一,以其响应式数据绑定和组件化开发赢得了广大开发者的喜爱。随着前端技术的不断发展和项目复杂度的增加,Vue 团队推出了 Vue 3,并引入了 Composition API,以更好地满足复杂应用的需求。

一、Composition API 是什么?

Composition API 是 Vue 3 中新增的一组 API,它允许开发者使用函数式编程的方式来组织和复用组件逻辑。与 Vue 2 中的 Options API(如 datamethodscomputed 等选项)不同,Composition API 提供了一种更加灵活和可组合的方式来编写组件逻辑。

二、为什么需要 Composition API?

  1. 更好的代码组织:随着组件功能的增加,Options API 可能会导致代码难以维护和理解。Composition API 通过将逻辑拆分为多个可复用的函数,提高了代码的可读性和可维护性。

  2. 逻辑复用:在 Options API 中,复用逻辑通常需要通过 mixins 或高阶组件实现,但这些方式可能导致命名冲突和关系不清晰。Composition API 中的函数可以像普通 JavaScript 函数一样被复用,无需担心命名冲突。

  3. 更好的 TypeScript 支持:Vue 3 与 TypeScript 的集成更加紧密,而 Composition API 的函数式编程风格更适合 TypeScript 的类型推断和静态检查。

三、Composition API 的核心概念

  1. reactive 和 ref:这两个函数用于创建响应式数据。reactive 用于创建响应式对象,而 ref 用于创建响应式引用。它们都是 Vue 3 的响应式系统的核心。

    • reactive:返回一个响应式代理对象,该对象在被访问或修改时会触发相应的依赖更新。
    • ref:返回一个响应式引用对象,其内部值可以通过 .value 属性访问或修改。
  2. computed:用于创建计算属性。计算属性是基于响应式数据派生出的新数据,当依赖的数据变化时,计算属性会自动更新。

  3. watch 和 watchEffect:用于侦听响应式数据的变化,并在数据变化时执行相应的回调函数。

    • watch:需要显式指定侦听的数据源和回调函数,支持立即执行、深度侦听等选项。
    • watchEffect:自动侦听回调函数中使用的响应式数据,无需显式指定数据源。当回调函数中使用的数据变化时,watchEffect 会自动重新执行回调函数。
  4. setup 函数:Composition API 的入口函数,用于替代 Vue 2 中的 datamethodscomputed 等选项。在 setup 函数中,开发者可以定义和导出组件所需的响应式数据、计算属性、方法等。

四、使用 Composition API 编写组件

使用 Composition API 编写组件时,通常需要在组件的 setup 函数中定义和导出所需的响应式数据、计算属性和方法等。然后,在组件的模板中可以直接使用这些导出的值和方法。

以下是一个使用 Composition API 编写的简单 Vue 3 组件示例:

 

vue复制代码

<template>
<div>
<p>{{ count }}</p>
<button @click="increment">Increment</button>
</div>
</template>
<script>
import { ref } from 'vue';
export default {
setup() {
const count = ref(0); // 定义响应式引用 count,初始值为 0
const increment = () => { // 定义方法 increment,用于增加 count 的值
count.value++; // 修改响应式引用的值时,需要使用 .value 属性
};
return { // 导出 count 和 increment,供模板中使用
count,
increment
};
}
};
</script>

五、总结与展望

Composition API 为 Vue 3 带来了更加灵活和可组合的代码组织方式,使得开发者能够更好地应对复杂应用的挑战。同时,Composition API 也为 Vue 与 TypeScript 的集成提供了更好的支持,有助于提升代码的类型安全和可维护性。随着 Vue 3 的不断发展和完善,相信 Composition API 将在前端开发中发挥越来越重要的作用。


http://www.niftyadmin.cn/n/5405867.html

相关文章

c++八股文:c++新特性

文章目录 [toc] 1.C11的新特性有哪些2.智能指针3.类型推导4.左值和右值5.nullptr6.范围for循环7.lambda表达式参考 1.C11的新特性有哪些 语法的改进 &#xff08;1&#xff09;统⼀的初始化⽅法 &#xff08;2&#xff09;成员变量默认初始化 &#xff08;3&#xff09;auto关…

C++/数据结构:AVL树

目录 一、AVL树的概念 二、AVL树的实现 2.1节点定义 2.2节点插入 三、AVL树的旋转 3.1新节点插入较高左子树的左侧&#xff1a;右单旋 3.2新节点插入较高右子树的右侧&#xff1a;左单旋 3.3新节点插入较高左子树的右侧---左右&#xff1a;先左单旋再右单旋 3.4新节点插…

MIT-BEVFusion系列九--CUDA-BEVFusion部署6 前向推理的数据加载与图像预处理

目录 加载图像数据加载点云数据模型推理并计时预热操作模型推理检查点云输入数据量打印信息中CopyLidar部分的计算和耗时打印信息中ImageNrom图像预处理部分计算和耗时 该系列文章与qwe、Dorothea一同创作&#xff0c;喜欢的话不妨点个赞。 接上面的文章&#xff0c;目光聚焦回…

12种算法优化CNN-BiGRU-Attention单变量输入单步预测,机器学习预测全家桶,持续更新,MATLAB代码...

截止到本期MATLAB机器学习预测全家桶&#xff0c;一共发了15篇关于机器学习预测代码的文章。算上这一篇&#xff0c;一共16篇&#xff01;参考文章如下&#xff1a; 1.五花八门的机器学习预测&#xff1f;一篇搞定不行吗&#xff1f; 2.机器学习预测全家桶&#xff0c;多步预测…

剑指offer经典题目整理(一)

一、字符串空格替换%20 1.链接 替换空格_牛客题霸_牛客网 (nowcoder.com) 2.描述 请实现一个函数&#xff0c;将一个字符串s中的每个空格替换成“%20”。 例如&#xff0c;当字符串为We Are Happy.则经过替换之后的字符串为 We%20Are%20Happy。 3.思路 直接采用相关容器…

mybatis plus 根据要求构建sql wrapper

文章目录 要求: 构建sql wrapper错误写法解决方案 要求: 构建sql wrapper 根据要求构建sql wrapper&#xff1a;dto.getProjectId() null&#xff0c;则 where project_id is nulldto.getProjectId() ! null&#xff0c;则 where project_id 58b1fad6-adaa-4834-8337-8d43834…

深度神经网络压缩与加速关键技术的研究

摘要 文章针对深度神经网络参数存在大量冗余性问题&#xff0c;从压缩与加速深度神经网络两种不同任务出发&#xff0c;对深度神经网络的低秩分解&#xff08;low-rank decomposition&#xff09;和参数剪枝&#xff08;parameter pruning&#xff09;通用性方法展开深入研究&…

JVM运行时数据区——虚拟机栈

文章目录 1、虚拟机栈概述1.1、StackOverflowError1.2、OOM异常 2、栈的存储单位3、局部变量表3.1、局部变量表简介3.2、Slot 4、操作数栈5、栈顶缓存技术6、动态链接7、方法的调用7.1、方法调用的分类7.2、虚方法与非虚方法7.3、关于invokedynamic指令7.4、方法重写的本质7.5、…