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 可能需要一些努力,但长远来看,这将使代码更加清晰、可维护,并为未来的项目开发打下坚实的基础。
相关文章:

Vue 3的Composition API和vue2的不同之处
Vue 3的Composition API是Vue.js框架的一个重要更新,它提供了一种新的组件逻辑组织和复用方式。在Vue 2中,我们通常使用Options API(data、methods、computed等)来组织组件的逻辑,但这种组织方式在处理复杂组件时可能会…...
go语言基础 -- 面向对象编程
go语言面向对象编程思想 面向对象编程离不开封装、继承、多态三个特性,go语言与其他c、java不太一样,没有类的概念,面向对象的实现也有些区别,下面分别描述。 go语言封装 结构体中字段如欲对外隐藏,首字母小写&…...

HarmonyOS—编译构建概述
编译构建是将应用/服务的源代码、资源、第三方库等,通过编译工具转换为可直接在硬件设备上运行的二进制机器码,然后再将二进制机器码封装为HAP/APP软件包,并为HAP/APP包进行签名的过程。其中,HAP是可以直接运行在模拟器或真机设备…...
下载element-ui 资源,图标 element-icons.woff,element-icons.ttf 无法解码文件字体
css下载地址:https://unpkg.com/element-ui2.15.14/lib/theme-chalk/index.css js下载地址:https://unpkg.com/element-ui2.15.14/lib/index.js 图标及文字文件下载地址: element-icons.woff:: https://unpkg.com/element-…...

Flutter整体框架
Flutter整体框架由三部分组成:Framework、Engine和Embedder。 Framework Framework提供了一个用 Dart 语言编写的现代、反应式框架,由许多抽象的层级组成。它包括一套丰富的布局、动画、绘制、手势UI组件及配套代码,以及更基础的异步、文件、…...
JVM堆内存中新生代晋升到老年代的条件
1. 一般年龄判断 当对象在Eden区中经过第一次 Minor GC 后,如果仍然存活,则会被移动到 From Survivor 区,并且对象的年龄设为 1。每经过一次 Minor GC,存活下来的对象年龄加 1,若存活对象在 From Survivor 区的年龄达…...

前端监控为什么采用GIF图片做埋点?
一、什么是埋点监控 前端监控是开发人员用来跟踪和维护应用程序表现层的运行状况的过程和工具。它主要包括三种类型:数据监控、性能监控和异常监控。 1、数据监控 主要是为了收集跟用户相关的数据,例如用户设备类型、浏览器版本、页面浏览量(…...

webstorm 创建运行纯Typescript项目
创建一个空项目,在项目根目录创建一个tsconfig.json文件自动配置: 打开终端输入tsc --init,即可自动生成tsconfig.json文件手动配置: 在项目根目录下新建一个tsconfig.json文件,并配置如下内容 具体配置可以直接使用下面的配置&am…...

GO-接口
1. 接口 在Go语言中接口(interface)是一种类型,一种抽象的类型。 interface是一组method的集合,接口做的事情就像是定义一个协议(规则),只要一台机器有洗衣服和甩干的功能,我就称它…...

【C语言】动态内存管理常用函数
前言 我们在之前学习的数组开辟的空间是固定不变的,有时候我们需要的空间⼤⼩在程序运⾏的时候才能知道~ c语言中的动态内存开辟,让程序员⾃⼰可以根据实际需求申请和释放相应空间,这使得空间的开辟变得灵活了许多。 欢迎关注个人主页&#x…...

【OpenGL】(1) 专栏介绍:OpenGL 库 | 3D 计算机图形应用 | GPGPU 计算 | 3D 建模和 3D动画 | 渲染技术介绍
🔗 《C语言趣味教程》👈 猛戳订阅!!! 💭 写在前面:本专栏主要内容是关于 3D 计算机图形技术的学习,重点是学习与此技术相关的 3D 实时渲染 (3D real-time rendering) 技术。我们会以…...
SPI总线知识总结
1 SPI的时钟极性CPOL和时钟相位CPHA的设置 1.1 SPI数据传输位数 SPI传输数据过程中总是先发送或接收高字节数据,每个时钟周期接收器或发送器左移一位数据。对于小于16位的数据,在发送前必须左对齐,如果接收的数据小于16位,则采用软…...
【异常关闭clas*h,导致无法访问任何网页_解决办法】
各位经常使用Clash Scientific浏览的朋友们,我要建议大家不要在开启Clash代理的情况下直接关机或者重启电脑,这样的操作会导致网络配置出现严重问题,带来不必要的麻烦。 这是我亲身体验的一次痛苦教训。不管是我在关闭or开启Clas*h代理后&am…...

STL-map和set
目录 一、关联式容器 二、键值对 三、树形结构的关联式容器 3.1 set 3.1.1 set介绍 3.1.2 set的使用 1. set的模板参数列表 2. set的构造 3. set的迭代器(类型是双向迭代器) 4. set的容量 5.set修改操作 6、operator 7. set的使用举例 3.2 map 3.2.1map介绍 3.2.2map的…...
[蓝桥杯 2020 省 B1] 整除序列
[蓝桥杯 2020 省 B1] 整除序列 题目描述 有一个序列,序列的第一个数是 n n n,后面的每个数是前一个数整除 2 2 2,请输出这个序列中值为正数的项。 输入格式 输入一行包含一个整数 n n n。 输出格式 输出一行,包含多个整数…...

【Android】View 的滑动
View 的滑动是 Android 实现自定义控件的基础,同时在开发中我们也难免会遇到 View 的滑动处理。其实不管是哪种滑动方式,其基本思想都是类似的:当点击事件传到 View 时,系统记下触摸点的坐标,手指移动时系统记下移动后…...

基于ZYNQ的PCIE高速数据采集卡的设计(一)
作为信息处理的第一步,数据采集的作用越来越重要。目前,数据采集已经在航 空、民用、军事、医疗等领域得到广泛应用。随着相关技术的不断发展,信号频率越 来高,带宽越来越大,使得数据采集技术逐渐向高速大数据的方向…...
渗透测试工具 nmap 详解
官网:Nmap: the Network Mapper - Free Security Scanner -p<端口范围>:仅扫描指定的端口 用于扫描指定端口是否开放,在 -p 后输入指定的端口,以英文","进行拼接多个指定端口。 nmap -p 80&…...

Ubuntu下安装Scala
前言 弄了一下终于成功装上了,这里对此进行一下总结 安装虚拟机 VMware虚拟机安装Ubuntu(超详细图文教程)_vmware安装ubuntu-CSDN博客https://blog.csdn.net/qq_43374681/article/details/129248167Download Ubuntu Desktop | Download | …...

无法启动报,To install it, you can run: npm install --save @/components/iFrame/index
运行的过程中后台报错 npm install --save /components/iFrame/index,以为是安装三方依赖错误,经过多次重装node_modules依然没有用。 没办法,只能在项目中搜索 components/iFrame/index这个文件。。突然醒悟。。。 有时候,犯迷…...
Vim 调用外部命令学习笔记
Vim 外部命令集成完全指南 文章目录 Vim 外部命令集成完全指南核心概念理解命令语法解析语法对比 常用外部命令详解文本排序与去重文本筛选与搜索高级 grep 搜索技巧文本替换与编辑字符处理高级文本处理编程语言处理其他实用命令 范围操作示例指定行范围处理复合命令示例 实用技…...

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式
一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明:假设每台服务器已…...
脑机新手指南(八):OpenBCI_GUI:从环境搭建到数据可视化(下)
一、数据处理与分析实战 (一)实时滤波与参数调整 基础滤波操作 60Hz 工频滤波:勾选界面右侧 “60Hz” 复选框,可有效抑制电网干扰(适用于北美地区,欧洲用户可调整为 50Hz)。 平滑处理&…...

VB.net复制Ntag213卡写入UID
本示例使用的发卡器:https://item.taobao.com/item.htm?ftt&id615391857885 一、读取旧Ntag卡的UID和数据 Private Sub Button15_Click(sender As Object, e As EventArgs) Handles Button15.Click轻松读卡技术支持:网站:Dim i, j As IntegerDim cardidhex, …...

练习(含atoi的模拟实现,自定义类型等练习)
一、结构体大小的计算及位段 (结构体大小计算及位段 详解请看:自定义类型:结构体进阶-CSDN博客) 1.在32位系统环境,编译选项为4字节对齐,那么sizeof(A)和sizeof(B)是多少? #pragma pack(4)st…...

Python爬虫(一):爬虫伪装
一、网站防爬机制概述 在当今互联网环境中,具有一定规模或盈利性质的网站几乎都实施了各种防爬措施。这些措施主要分为两大类: 身份验证机制:直接将未经授权的爬虫阻挡在外反爬技术体系:通过各种技术手段增加爬虫获取数据的难度…...

前端开发面试题总结-JavaScript篇(一)
文章目录 JavaScript高频问答一、作用域与闭包1.什么是闭包(Closure)?闭包有什么应用场景和潜在问题?2.解释 JavaScript 的作用域链(Scope Chain) 二、原型与继承3.原型链是什么?如何实现继承&a…...

Mac下Android Studio扫描根目录卡死问题记录
环境信息 操作系统: macOS 15.5 (Apple M2芯片)Android Studio版本: Meerkat Feature Drop | 2024.3.2 Patch 1 (Build #AI-243.26053.27.2432.13536105, 2025年5月22日构建) 问题现象 在项目开发过程中,提示一个依赖外部头文件的cpp源文件需要同步,点…...

基于Springboot+Vue的办公管理系统
角色: 管理员、员工 技术: 后端: SpringBoot, Vue2, MySQL, Mybatis-Plus 前端: Vue2, Element-UI, Axios, Echarts, Vue-Router 核心功能: 该办公管理系统是一个综合性的企业内部管理平台,旨在提升企业运营效率和员工管理水…...
Kafka主题运维全指南:从基础配置到故障处理
#作者:张桐瑞 文章目录 主题日常管理1. 修改主题分区。2. 修改主题级别参数。3. 变更副本数。4. 修改主题限速。5.主题分区迁移。6. 常见主题错误处理常见错误1:主题删除失败。常见错误2:__consumer_offsets占用太多的磁盘。 主题日常管理 …...