Vue 组合式 API 与 选项式 API 全面对比教程

一、前言:Vue 的两种 API 风格

Vue 提供了两种编写组件逻辑的方式:组合式 API (Composition API)选项式 API (Options API)。理解这两种方式的区别和适用场景,对于 Vue 开发者至关重要。

为什么会有两种 API?

  • 选项式 API:Vue 2 的传统方式,按照选项(data、methods 等)组织代码
  • 组合式 API:Vue 3 引入的新方式,基于函数组合逻辑,更适合复杂组件

二、选项式 API (Options API) 详解

1. 基本结构

<script>
export default {// 数据选项data() {return {count: 0,message: 'Hello Vue!'}},// 计算属性computed: {reversedMessage() {return this.message.split('').reverse().join('')}},// 方法methods: {increment() {this.count++}},// 生命周期钩子mounted() {console.log('组件已挂载')}
}
</script><template><div><p>{{ message }}</p><p>反转: {{ reversedMessage }}</p><button @click="increment">计数: {{ count }}</button></div>
</template>

2. 选项式 API 的特点

  • 按选项组织代码:将代码分为 data、methods、computed 等固定选项
  • this 上下文:通过 this 访问组件实例
  • 隐式响应式:data 返回的对象自动成为响应式
  • 适合简单组件:逻辑较少时结构清晰

3. 生命周期钩子

export default {beforeCreate() {},created() {},beforeMount() {},mounted() {},beforeUpdate() {},updated() {},beforeUnmount() {},unmounted() {}
}

三、组合式 API (Composition API) 详解

1. 基本结构(<script setup> 语法)

<script setup>
import { ref, computed, onMounted } from 'vue'// 响应式状态
const count = ref(0)
const message = ref('Hello Vue!')// 计算属性
const reversedMessage = computed(() => {return message.value.split('').reverse().join('')
})// 方法
function increment() {count.value++
}// 生命周期钩子
onMounted(() => {console.log('组件已挂载')
})
</script><template><div><p>{{ message }}</p><p>反转: {{ reversedMessage }}</p><button @click="increment">计数: {{ count }}</button></div>
</template>

2. 组合式 API 的特点

  • 基于函数:通过导入函数实现各种功能
  • 逻辑组合:可以自由组织相关代码
  • 显式响应式:需要明确使用 ref/reactive
  • 更好的 TypeScript 支持:类型推断更自然
  • 逻辑复用:可以提取和重用逻辑(组合函数)

3. 核心响应式 API

API用途选项式 API 对应物
ref创建基本类型的响应式数据data 中的基本类型
reactive创建对象的响应式代理data 中的对象
computed创建计算属性computed 选项
watch监听响应式数据变化watch 选项
watchEffect自动追踪依赖的响应式效果-

4. 生命周期钩子对照

选项式 API组合式 API
beforeCreate不需要(直接写在 setup 中)
created不需要(直接写在 setup 中)
beforeMountonBeforeMount
mountedonMounted
beforeUpdateonBeforeUpdate
updatedonUpdated
beforeUnmountonBeforeUnmount
unmountedonUnmounted

四、两种 API 的深度对比

1. 代码组织方式

选项式 API

export default {data() { /*...*/ },    // 数据computed: { /*...*/ }, // 计算属性methods: { /*...*/ },  // 方法watch: { /*...*/ }     // 监听器
}

组合式 API

// 功能A相关代码
const { x, y } = useFeatureA()// 功能B相关代码
const { a, b } = useFeatureB()

2. 逻辑复用对比

选项式 API 复用(mixins)

// mixin.js
export default {data() {return {mixinData: 'Mixin Data'}},methods: {mixinMethod() { /*...*/ }}
}// 组件中使用
import myMixin from './mixin.js'
export default {mixins: [myMixin]
}

组合式 API 复用(组合函数)

// useFeature.js
export function useFeature() {const state = ref(null)function doSomething() { /*...*/ }return { state, doSomething }
}// 组件中使用
import { useFeature } from './useFeature.js'
const { state, doSomething } = useFeature()

3. 类型支持对比

  • 选项式 API:类型推断有限,特别是在使用 mixins 时
  • 组合式 API:天然支持 TypeScript,类型推断更准确

五、何时使用哪种 API?

选项式 API 适合:

  • 小型到中型项目
  • 简单组件开发
  • 熟悉 Vue 2 的开发者
  • 需要快速原型开发时

组合式 API 适合:

  • 大型复杂项目
  • 需要更好逻辑组织的组件
  • 需要逻辑复用的场景
  • TypeScript 项目
  • 团队希望统一代码风格

六、组合式 API 进阶技巧

1. 自定义组合函数示例

// useCounter.js
import { ref } from 'vue'export function useCounter(initialValue = 0) {const count = ref(initialValue)function increment() {count.value++}function decrement() {count.value--}function reset() {count.value = initialValue}return {count,increment,decrement,reset}
}

组件中使用:

<script setup>
import { useCounter } from './useCounter'const { count, increment } = useCounter(10)
</script><template><button @click="increment">Count: {{ count }}</button>
</template>

2. 异步状态管理

<script setup>
import { ref } from 'vue'const data = ref(null)
const loading = ref(false)
const error = ref(null)async function fetchData() {loading.value = trueerror.value = nulltry {const response = await fetch('/api/data')data.value = await response.json()} catch (err) {error.value = err} finally {loading.value = false}
}// 立即获取数据
fetchData()
</script>

3. 组件通信

<!-- Parent.vue -->
<script setup>
import { ref } from 'vue'
import Child from './Child.vue'const msg = ref('Hello from parent')
</script><template><Child v-model="msg" />
</template><!-- Child.vue -->
<script setup>
defineProps(['modelValue'])
defineEmits(['update:modelValue'])
</script><template><input:value="modelValue"@input="$emit('update:modelValue', $event.target.value)"/>
</template>

七、迁移策略:从选项式到组合式

1. 渐进式迁移

  • 新组件使用组合式 API
  • 旧组件逐步重构
  • 混合使用(在选项式组件中使用 setup 选项)

2. 对应关系记忆卡

选项式 API组合式 API
this不需要,直接访问变量
data()ref()reactive()
methods普通函数
computedcomputed()
watchwatch()watchEffect()
生命周期钩子onXxx() 系列函数
propsdefineProps()
emitsdefineEmits()
mixins组合函数

八、常见问题解答

1. 两种 API 可以混用吗?

可以,但不推荐。在 Vue 3 中,你可以在组件中使用 setup() 选项来使用组合式 API,同时保留其他选项。

2. 组合式 API 更难学吗?

对于 Vue 新手,选项式 API 可能更容易上手。但有其他框架经验的开发者,组合式 API 可能更直观。

3. 性能有差异吗?

两种 API 在性能上没有显著差异,组合式 API 在某些场景下可能有轻微优势。

4. 公司项目该用哪种?

新项目推荐组合式 API,旧项目可以逐步迁移。团队统一风格最重要。

九、总结

Vue 的两种 API 风格各有优势:

  • 选项式 API:结构清晰,学习曲线平缓,适合简单场景
  • 组合式 API:灵活强大,便于逻辑复用和组织,适合复杂场景

建议开发者:

  1. 先掌握选项式 API 理解 Vue 核心概念
  2. 逐渐过渡到组合式 API
  3. 根据项目需求和个人偏好选择合适的方式
  4. 大型项目推荐统一使用组合式 API

组合式 API 代表了 Vue 的未来发展方向,特别是对于复杂应用和需要良好 TypeScript 支持的项目。选项式 API 仍会长期支持,适合维护旧项目和简单场景。

创作不易,如果您都看到这里了,可以给我一个点赞、收藏并关注一下么?您的支持与喜爱是激励我创作的最大动力!

如果内容有误请及时联系我进行修改!

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

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

相关文章

HarmonyOS 应用模块化设计 - 面试核心知识点

HarmonyOS 应用模块化设计 - 面试核心知识点 在 HarmonyOS 开发面试中&#xff0c;模块化设计是必考知识点。本文从面试官角度深度解析 HarmonyOS 应用模块化设计&#xff0c;涵盖 HAP、HAR、HSP 等核心概念&#xff0c;助你轻松应对技术面试&#xff01; &#x1f3af; 面试高…

Maven高级学习笔记

分模块设计 为什么分模块设计?将项目按照功能拆分成若干个子模块&#xff0c;方便项目的管理维护、扩展&#xff0c;也方便模块间的相互调用&#xff0c;资源共享。 注意事项&#xff1a;分模块开发需要先针对模块功能进行设计&#xff0c;再进行编码。不会先将工程开发完毕&…

[创业之路-423]:经济学 - 大国竞争格局下的多维博弈与科技核心地位

在当今风云变幻的国际舞台上&#xff0c;大国竞争已成为时代的主旋律&#xff0c;其激烈程度与复杂性远超以往。这场全方位的较量&#xff0c;涵盖了制度、思想、文化、经济、科技、军事等诸多关键领域&#xff0c;每一个维度都深刻影响着大国的兴衰成败&#xff0c;而科技在其…

【企业容灾灾备系统规划】

一、企业灾备体系 1.1 灾备体系 灾备切换的困境: 容灾领域的标准化方法和流程、算法体系是确保业务连续性和数据可靠性的核心,以下从标准框架、流程规范、算法体系三个维度进行系统分析: 1.1.1、标准化方法体系​ ​1. 容灾等级标准​ ​国际标准SHARE78​: 将容灾能力划…

Kafka Connect基础入门与核心概念

一、Kafka Connect是什么&#xff1f; Apache Kafka Connect是Kafka生态中用于构建可扩展、可靠的数据集成管道的组件&#xff0c;它允许用户将数据从外部系统&#xff08;如数据库、文件系统、API等&#xff09;导入Kafka&#xff08;Source Connector&#xff09;&#xff0…

从零手写Java版本的LSM Tree (四):SSTable 磁盘存储

&#x1f525; 推荐一个高质量的Java LSM Tree开源项目&#xff01; https://github.com/brianxiadong/java-lsm-tree java-lsm-tree 是一个从零实现的Log-Structured Merge Tree&#xff0c;专为高并发写入场景设计。 核心亮点&#xff1a; ⚡ 极致性能&#xff1a;写入速度超…

Kotlin的5个主要作用域函数

applay, also,let, run, with 是kotlin标准库提供的5个主要的作用域函数&#xff08;Scope Functions&#xff09;​&#xff0c;它们的设计目的是为了在特定作用域内更简洁地操作对象。 如何使用这5个函数&#xff0c;要从它的设计目的来区分&#xff1a; apply : 配置/对象…

原型模式Prototype Pattern

模式定义 用原型实例指定创建对象的种类&#xff0c;并且通过复制这些原型创建新的对象&#xff0c;其允许一个对象再创建 另外一个可定制的对象&#xff0c;无须知道任何创建的细节 对象创建型模式 基本工作原理是通过将一个原型对象传给那个要发动创建的对象&#xff0c;这…

基于深度学习的智能交通流量预测系统:技术与实践

前言 随着城市化进程的加速&#xff0c;交通拥堵问题日益严重&#xff0c;给人们的日常生活和经济发展带来了巨大的挑战。智能交通系统&#xff08;ITS&#xff09;作为解决交通问题的重要手段&#xff0c;逐渐成为研究的热点。其中&#xff0c;交通流量预测是智能交通系统中的…

Cilium动手实验室: 精通之旅---23.Advanced Gateway API Use Cases

Cilium动手实验室: 精通之旅---23.Advanced Gateway API Use Cases 1. Lab说明1.1 高级网关 API 使用案例 2. 负载均衡器2.1 部署应用程序2.2 部署 Gateway 和 HTTPRoute 3. HTTP 标头请求修饰符3.1 部署 HTTPRoute3.2 可观测性 4. HTTP 响应标头重写5. HTTP 流量镜像5.1 demo应…

Agentic Workflow是什么?Agentic Workflow会成为下一个AI风口吗?

无论是想要学习人工智能当做主业营收&#xff0c;还是像我一样作为开发工程师但依然要运用这个颠覆开发的时代宠儿&#xff0c;都有必要了解、学习一下人工智能。 近期发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;入行门槛低&#x…

Some chunks are larger than 500 KiB after minification. Consider

在 vue3vite 项目开发中&#xff0c;build 打包时出现以下警告报错&#xff1a; (!) Some chunks are larger than 500 KiB after minification. Consider: - Using dynamic import() to code-split the application - Use build.rollupOptions.output.manualChunks to improve…

NodeJS11和10以及之前的版本,关键差异?

Node.js 11 相比 10&#xff08;及更早版本&#xff09;&#xff0c;除了事件循环行为的重大改变&#xff0c;还有多个核心模块和底层机制的升级。以下是它们的关键差异和新特性对比&#xff0c;帮助你快速掌握两个版本的重要变化。 &#x1f527; 一、事件循环行为变化&#x…

调和级数 敛散性

调和级数的敛散性是一个非常经典的问题。我们来全面分析它。 &#x1f9e0; 调和级数定义 调和级数是指&#xff1a; ∑ n 1 ∞ 1 n 1 1 2 1 3 1 4 ⋯ \sum_{n1}^{\infty} \frac{1}{n} 1 \frac{1}{2} \frac{1}{3} \frac{1}{4} \cdots n1∑∞​n1​121​31​41​⋯ …

Python•元组集合字符串

ʕ⸝⸝⸝˙Ⱉ˙ʔ ♡ 元组&#x1f6e5;️创建访问修改解包其他操作比较的依据 集合&#x1f6f8;创建添加和删除其他操作 字符串&#x1fa82;创建索引和切片基本操作连接加号join() 重复查找in 关键字index()find()startswith()endswith() ​​替换​​分割​​大小写删除 能…

​​信息系统项目管理师-项目整合管理 知识点总结与例题分析​​

​​一、项目整合管理概述​​ ​​1. 定义与重要性​​ 项目整合管理是项目管理知识领域中的核心过程,它协调所有其他知识领域的过程和活动,确保项目各要素有效整合。其核心目标是: ​​统一项目目标​​:确保各要素服务于共同目标​​协调冲突​​:解决项目执行中的各…

『uniapp』onThemeChange监听主题样式,动态主题不正确生效,样式被覆盖的坑

目录 问题示例代码解决思路1&#xff08;缺点影响显示效果有延迟&#xff09;解决思路2——通过路由刷新页面&#xff08;缺点只适用于部分网页&#xff09;解决思路3——vuex&#xff08;没学会~&#xff09;总结 欢迎关注 『uniapp』 专栏&#xff0c;持续更新中 欢迎关注 『…

LeetCode 高频 SQL 50 题(基础版)【题解】合集

点击下方标题可跳转至对应部分&#xff1a; LeetCode 高频 SQL 50 题&#xff08;基础版&#xff09;之 【查询】部分 LeetCode 高频 SQL 50 题&#xff08;基础版&#xff09;之 【连接】部分 上 LeetCode 高频 SQL 50 题&#xff08;基础版&#xff09;之 【连接】部分 下…

Jenkins 全面深入学习目录

Jenkins 全面深入学习目录 第一部分&#xff1a;Jenkins 基础入门 Jenkins 概述 持续集成/持续交付(CI/CD)概念Jenkins 的历史与发展Jenkins 与其他 CI/CD 工具的比较 Jenkins 安装与配置 系统要求与环境准备不同操作系统下的安装方法初始配置与安全设置插件管理系统 Jenkins…

安装laravel11和laravel12的一些报错问题解决

前言 今天在安装laravel的过程中遇到一些报错问题&#xff0c;记录一下。 laravel 12 Root composer.json requires laravel/tinker ^2.10.1, found laravel/tinker[2.x-dev] but it does not match your minimum-stability laravel/framework[v12.0.0, ..., v12.15.0] requ…