Vue 3的Composition API和vue2的不同之处

        Vue 3的Composition API是Vue.js框架的一个重要更新,它提供了一种新的组件逻辑组织和复用方式。在Vue 2中,我们通常使用Options API(data、methods、computed等)来组织组件的逻辑,但这种组织方式在处理复杂组件时可能会导致代码分散和难以维护。Composition API的引入旨在解决这些问题,提供了一种更加灵活和高效的代码组织方式。
        在本篇文章中,我们将详细介绍Vue 3的Composition API与Vue 2的不同之处,并通过代码例子来展示其用法。


        一、响应式系统的变化
        Vue 2使用Object.defineProperty来实现响应式系统,而Vue 3引入了Proxy-based响应式系统。Proxy可以直接监听对象和数组的变化,而不需要像Vue 2那样为每个属性定义getter和setter。这使得Vue 3的响应式系统更加高效,特别是在处理大型数据集时。
        在Vue 2中,我们通常使用this来访问组件的响应式数据和方法。而在Vue 3的Composition API中,我们使用ref和reactive来创建响应式数据,使用setup函数来组织组件的逻辑。
        二、setup函数
        在Vue 3中,每个组件都可以定义一个setup函数,它是组件生命周期的一部分,在组件实例创建之前执行。setup函数是使用Composition API组织组件逻辑的地方,它接收两个参数:props和context。
        props是一个对象,包含了父组件传递给子组件的所有属性。context是一个普通的JavaScript对象,包含了attrs、slots和emit三个属性,分别用于访问组件的属性、插槽和事件。
        在setup函数中,我们可以使用ref和reactive来创建响应式数据,使用computed和watch来创建计算属性和侦听器,以及使用生命周期钩子函数来处理组件的生命周期事件。
        三、ref和reactive
        在Vue 3中,我们可以使用ref和reactive来创建响应式数据。ref用于创建一个响应式的引用对象,它可以是基本数据类型或对象类型。reactive用于创建一个响应式的对象,它只能是对象类型。
        下面是一个使用ref和reactive的例子:


import { ref, reactive } from 'vue';
export default {setup() {const count = ref(0);const state = reactive({name: 'Vue 3',age: 3});function increment() {count.value++;}return {count,state,increment};}
};


       

         四、computed和watch
        在Vue 3中,我们可以使用computed和watch来创建计算属性和侦听器。computed用于创建一个计算属性,它接收一个getter函数,并返回一个不可变的响应式引用对象。watch用于侦听一个响应式数据的变化,并在数据变化时执行一个回调函数。
        下面是一个使用computed和watch的例子:


import { ref, computed, watch } from 'vue';
export default {setup() {const count = ref(0);const doubled = computed(() => count.value * 2);watch(count, (newValue, oldValue) => {console.log(`Count changed from ${oldValue} to ${newValue}`);});function increment() {count.value++;}return {count,doubled,increment};}
};


        五、生命周期钩子函数
        在Vue 3中,我们可以使用生命周期钩子函数来处理组件的生命周期事件。生命周期钩子函数与Vue 2中的生命周期钩子类似,但需要从'vue'包中导入。
        下面是一个使用生命周期钩子函数的例子:


import { onMounted, onUpdated, onUnmounted } from 'vue';
export default {setup() {onMounted(() => {console.log('Component mounted');});onUpdated(() => {console.log('Component updated');});onUnmounted(() => {console.log('Component unmounted');});return {};}
};


        六、Composition API的优势
        Vue 3的Composition API相比于Vue 2的Options API具有以下优势:
        1. 逻辑复用:通过Composition API,我们可以将相同逻辑的代码片段组合在一起,而不必遵循Options API的固定结构。这极大地提高了代码的可读性和可维护性。
        2. 类型支持:Vue 3的Composition API在设计时就考虑了TypeScript的支持,提供了更好的类型支持,使得在使用TypeScript时可以获得更好的开发体验。
        3. 灵活性:Composition API提供了一种更加灵活的代码组织方式,使得开发者可以更好地组织和复用组件逻辑。
        总结
        Vue 3的Composition API是Vue.js框架的一个重要更新,它提供了一种新的组件逻辑组织和复用方式。通过setup函数、ref、reactive、computed、watch等API,我们可以更加灵活地组织和复用组件逻辑,提高代码的可读性和可维护性。Composition API的引入使得Vue 3在处理复杂组件逻辑时更加得心应手。此外,Composition API 还改善了类型支持,使得 Vue 3 与 TypeScript 的结合更加紧密,为大型项目和团队开发提供了更好的支持。
        七、与 Options API 的对比
        Vue 2 中的 Options API 是基于组件选项的组织方式,例如 `data`, `methods`, `computed`, `watch`, `lifecycle hooks` 等。每个选项都有自己的用途,而且它们是相互独立的。这种组织方式在简单组件中工作得很好,但在大型或复杂的组件中,可能会导致以下问题:
        1. 逻辑分散:相关的逻辑被分割到不同的选项中,使得理解和维护变得更加困难。
        2. 代码重用:在 Options API 中,代码重用通常需要使用混合(mixins)或高阶组件(Higher-Order Components, HOCs),这些方法都有其局限性,如命名空间冲突、隐式的依赖关系等。
        相比之下,Composition API 允许开发者将相关的逻辑放在一起,无论是计算属性、侦听器还是生命周期钩子,都可以在 `setup` 函数中声明和使用。这样,代码的组织更加清晰,重用也更加容易。
        八、迁移到 Composition API
        对于现有的 Vue 2 应用程序,迁移到 Vue 3 和 Composition API 并不是一个一键转换的过程。虽然 Vue 3 提供了兼容性构建,允许开发者逐步迁移,但迁移过程中仍需要手动调整代码。以下是一些迁移到 Composition API 时的建议:
        1. 逐步迁移:不需要一次性迁移整个应用程序。可以逐个组件地进行迁移,同时保持其他部分使用 Options API。
        2. 重构复杂组件:首先考虑重构那些逻辑复杂、难以维护的组件。
        3. 利用迁移工具:Vue 3 提供了一些迁移工具和指南,可以帮助开发者更顺利地完成迁移。
        九、示例:计数器组件
        下面是一个简单的计数器组件,分别使用 Vue 2 的 Options API 和 Vue 3 的 Composition API 实现。

//Vue 2 with Options API:export default {data() {return {count: 0};},methods: {increment() {this.count++;}},mounted() {console.log('Component mounted');}
};//Vue 3 with Composition API:import { ref, onMounted } from 'vue';
export default {setup() {const count = ref(0);function increment() {count.value++;}onMounted(() => {console.log('Component mounted');});return {count,increment};}
};


        十、结论
        Vue 3 的 Composition API 为 Vue.js 带来了新的活力,它不仅解决了 Vue 2 中的一些问题,还提供了更多的灵活性和强大的类型支持。虽然迁移到新的 API 可能需要一些努力,但长远来看,这将使代码更加清晰、可维护,并为未来的项目开发打下坚实的基础。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/722209.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

实体店好做还是电商平台好做?哪个发展前景较高?

我是电商珠珠 大部分人面对新的一年都会比较迷茫,想要创业会自己增加收入,却在开店和线上做电商这两者之间犹豫不决。不知道哪个更加合适自己,换句话来说,就是不知道哪个赔付率低一点。 现在这个行情,按照网友的说法…

C++ string类详解及模拟实现

目录 【本节目标】 1. 为什么学习string类? 1.1 C语言中的字符串 1.2 面试题(暂不做讲解) 2. 标准库中的string类 2.1 string类(了解) 2.2 string类的常用接口说明(注意下面我只讲解最常用的接口) 3. string类的模拟实现 3.1string类常用…

Express学习(一)

Express Express简介 什么是Express 官方给出的概念:Express是基于Node.js平台,快速、开放、极简的web开发框架。 通俗的理解:Express的作用和Node.js内置的http模块类似,是专门用来创建Web服务器的。进一步理解Express 不使用E…

【软件使用】Markdown编辑器第一次使用介绍

【软件使用】Markdown编辑器第一次使用介绍 markdown格式支持的软件有:VS Code 和 Typora,CSDN写网页博文也是用的.md,CSDN能支持导入的文件也是以.md格式结尾的文件名。 欢迎使用Markdown编辑器 你好! 这是你第一次使用 Markd…

C语言——结构体(位段)、联合体、枚举

hello,大家好!我是柚子,今天给大家分享的内容是C语言中的自定义类型结构体、联合体以及枚举,有什么疑问或建议可以在评论区留言,会顺评论区回访哦~ 一、结构体 struct a.结构体声明 不同于数组的是,结构…

【CSP试题回顾】202212-2-训练计划

CSP-202212-2-训练计划 解题思路 输入和初始化: 首先,代码从输入中获取项目的截止日期和项目数量。然后,它初始化一个项目列表,每个项目都有其依赖项、被依赖的项目集合、完成时间、总完成时间(包括依赖链&#xff09…

【JavaSE】面向对象——多态性

多态性 多态性的概念 所谓多态性,理解为一个事物的多种形态。具体点就是去完成某个动作时,不同的对象会产生不同的状态。 多态性的好处 多态在Java中指的是父类的引用指向子类的对象,或者可以说是子类的对象赋给父类的引用。这样在我们的…

SpringBoot实现分页模糊查询

1. Navicat查询数据 Navicat中查询所有数据 SELECT * FROM sys_user;Navicat中查询前两条数据(俩种方式) SELECT * FROM sys_user LIMIT 2; //从0开始,第一个参数是起始位置即(pageNum-1)*pageSize,第二个参数是步长 SELECT * …

项目部署后 通过公网IP访问不到的问题解决

目录 1.检查项目是否在运行(第二行命令) 2.检查所用服务器防火墙是否打开 3.检查linux系统防火墙有没有打开 问题如图: 首先确保项目已经成功部署 1.检查项目是否在运行(第二行命令) 第一行命令是监听58080端口,我的项目是使用该端口 2.检查所用云服务器防火墙是否打开 我…

分享77个Html杂七杂八模板,总有一款适合您

分享77个Html杂七杂八模板,总有一款适合您 77个Html杂七杂八模板下载链接:https://pan.baidu.com/s/1-RyIKaxdCu3dbnlMFMwviw?pwd8888 提取码:8888 学习知识费力气,收集整理更不易。知识付费甚欢喜,为咱码农谋福…

每日好题3.5

前缀和 这个题目巨妙,打的时候没写出来,后面补题发现太牛了 思路:当前区间左端点 L L L ,当我们向右移动一次,就相当于,原式 - f ( L ) f ( L 1 e 18 ) f(L) f(L 1e18) f(L)f(L1e18),值就…

linuxOPS基础_服务器构成

服务器的重要结构组成 家用电脑组成: CPU、主板、内存条、显卡、硬盘、电源、风扇、网卡、显示器、机箱、键盘鼠标等等。 CPU CPU是电脑的大脑, CPU发展史: 32 位CPU:最大的内存寻址地址2^32,大约4G的大小。 CP…

CSS3新特性

简介 继CSS2之后,CSS3增加了很多新的特性,虽然W3C仍在规范中,但是很多新的CSS3属性已经在很多现代浏览器中得到了支持。 CSS3边框 在CSS3中,可以创建圆角边框,添加边框阴影,设置边框图片,利用…

计算机组成原理之机器:计算机系统的基本概念

计算机组成原理之机器 笔记来源:哈尔滨工业大学计算机组成原理(哈工大刘宏伟) Chapter1:计算机系统的基本概念 1.1 计算机系统简介 从物理构成的角度对计算机系统分层 计算机组成原理主要关注微体系结构(Mirco-arc…

【无标题】计算机主要应用于哪些领域

科学计算(或称为数值计算)、数据处理(信息管理)、辅助工程、生产自动化、人工智能。1、科学计算(或称为数值计算):早期的计算机主要用于科学计算。目前,科学计算仍然是计算机应用的一…

【原理图PCB专题】Allegro模块化移动器件报...has the LOCKED property怎么解锁?

在模块化原理图时,PCB也需要做一个模块.mdd文件。这时需要先画好图纸然后再制作模块化文件。 修改文件时会发现模块化器件报错,无法编辑模块内部器件和走线,器件和走线都被LOCKED,如下所示报错内容: Symbol "U1" Selected Cannot edit Symbol "U1". M…

鸿蒙Harmony应用开发—ArkTS声明式开发(通用属性:组件标识)

id为组件的唯一标识,在整个应用内唯一。本模块提供组件标识相关接口,可以获取指定id组件的属性,也提供向指定id组件发送事件的功能。 说明: 从API Version 8开始支持。后续版本如有新增内容,则采用上角标单独标记该内容…

代码随想录算法训练营第九天

28. 实现 strStr() &#xff08;本题可以跳过&#xff09; 方法&#xff1a; 方法一&#xff1a; 暴力法 i 表示最多能移动到n-m位置&#xff0c; 超过则退出循环。j表示haystack 初始位置k表示needle的初始位置如果haystack [j] needle[k]且 k<m 则 j, k; 如果 km 则返…

OJ输入问题+准备

写在之前&#xff1a; 发现题目输入是这样的&#xff1a; 我的问题&#xff1a;如何通过空格分割这些输入的字符串并分别保存&#xff01;&#xff01;&#xff08;C语言scanf好解决一点但我选择C....&#xff09; C引入了ostringstream、istringstream、stringstream这三个类…

DevOps中集成自动化测试的具体案例

在DevOps中集成自动化测试的具体案例可以从多个角度进行分析,包括金融行业、分布式系统、大型企业等不同领域的实践。以下是几个具体的案例: 金融行业的DevOps实践:在金融行业中,DevOps被广泛应用于提升软件开发和运营的效率。例如,通过解析后台接口代码日志格式,自动化生…