【Vue3】Composition API vs Options API —— 什么场景该选哪个

一句话结论

小页面用 Options,大逻辑用 Composition。

不是什么 "Composition 取代 Options",两个都是 Vue 官方一等公民,选对场景比选对 API 重要。


Options API --- 房间分区清晰

每个功能都有固定格子:datamethodscomputedwatch

vue 复制代码
<script>
export default {
  data() {
    return { count: 0 }
  },
  methods: {
    increment() { this.count++ }
  },
  computed: {
    doubled() { return this.count * 2 }
  }
}
</script>

🚀 适合:

  • 简单页面(表单、弹窗、展示卡片)
  • 新人上手、团队习惯 Options
  • 组件逻辑 < 100 行

⚠️ 痛点:

一个功能横跨 data / methods / computed 三个格子,复杂组件里改一个功能要上下翻 5 次。


Composition API --- 按逻辑聚合

逻辑相关的代码堆在一起,想拆就拆。

vue 复制代码
<script setup>
import { ref, computed } from 'vue'

const count = ref(0)
const increment = () => count.value++
const doubled = computed(() => count.value * 2)
</script>

🚀 适合:

  • 复杂组件(500+ 行)
  • 多组件复用相同逻辑(鼠标跟踪、表单校验、请求状态)
  • TypeScript 项目(类型推断天然友好)

💡 面试加分玩法 --- 逻辑抽离:

ts 复制代码
// useMouseTracker.ts
import { ref, onMounted, onUnmounted } from 'vue'

export function useMouseTracker() {
  const x = ref(0)
  const y = ref(0)

  function update(e: MouseEvent) {
    x.value = e.clientX
    y.value = e.clientY
  }

  onMounted(() => window.addEventListener('mousemove', update))
  onUnmounted(() => window.removeEventListener('mousemove', update))

  return { x, y }
}
vue 复制代码
<!-- 使用 -->
<script setup>
import { useMouseTracker } from './useMouseTracker'
const { x, y } = useMouseTracker()
</script>

什么时候选哪个?一张表说清楚

场景 推荐 原因
简单表单/弹窗 Options 搭得快,不用动脑子
200+ 行的中型组件 都行 看团队习惯,别纠结
500+ 行大型组件 Composition 逻辑混在一起改不动了
跨组件复用逻辑 Composition useXxx() 天然可复用
TS 重度项目 Composition 类型推导不用写接口
新人有 Options 基础 Options 别为炫技增加学习成本
新上手的 Vue 新项目 Composition 现在是 Vue 主推方向

个人实战经验: 我的策略是"混用不混写"。一个组件里两个 API 可以并存 ------ 简单部分用 Options,复杂逻辑用 setup()。Composition 不是必须全盘抛弃 Options。

相关推荐
泯泷29 分钟前
第 2 篇:设计第一套字节码:Opcode、Instruction 与 Constant Pool
前端·javascript·安全
妙码生花29 分钟前
从 PHP 到 AI + Golang,程序员自救转型手记(十五):优化细节、网络请求封装
前端·后端·ai编程
泯泷29 分钟前
第 1 篇:从 1 + 2 开始:亲手写出第一台 JSVM
前端·javascript·安全
团团崽_七分甜31 分钟前
Spring Boot 核心知识点总结
前端
lichenyang4531 小时前
从一个按钮开始,理解 ASCF 框架到底在做什么
前端
古夕1 小时前
第三方 SSO 接入实践:redirect_uri 编码、回调一致性与跨项目联调
前端·vue.js
朦胧之1 小时前
页面白屏卡住排查方法
前端·javascript
用户593608741401 小时前
Playwright 黑魔法:用 ClipboardEvent 绕过 React 富文本编辑器
前端
石山岭2 小时前
自己动手写了一个 Android 虚拟定位 App:GPSSimulate 技术实
android·前端
犇驫聊AI2 小时前
Chrome DevTools MCP + Claude Code 自定义skills生成接口代码生成器
前端·javascript