news 2026/5/2 16:17:33

后端开发也能搞定 Vue3?从“类与对象”的角度通过 30 分钟看懂 Composition API

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
后端开发也能搞定 Vue3?从“类与对象”的角度通过 30 分钟看懂 Composition API

☕ 前言:为什么后端以前讨厌写前端?

作为后端开发,我们习惯了类 (Class)对象 (Object)封装 (Encapsulation)依赖注入 (DI)
当我们看到 Vue2 的代码时,内心是崩溃的:

  • 满屏的this:这个this到底指的是 Window 还是实例?
  • 代码割裂:实现一个“搜索”功能,变量要写在data里,逻辑要写在methods里,监听要写在watch里。屏幕滚来滚去,逻辑支离破碎。

Vue3 的 Composition API(组合式 API)简直就是后端开发者的福音。
别被这个高大上的名字吓到了。在后端眼里,它本质上就是把页面逻辑写成了“Java 类”!

今天,我们忘掉前端术语,用OOP 的视角重新认识 Vue3。


🧩 核心映射:Vue3 就是在写 Class

在 Java/Spring 中,我们写一个业务组件通常是这样的:

publicclassCounterService{// 1. 私有成员变量 (State)privateintcount=0;// 2. 构造函数/初始化 (Init)publicCounterService(){System.out.println("初始化...");}// 3. Getter 方法 (Computed)publicintgetDoubleCount(){returncount*2;}// 4. 公共方法 (Methods)publicvoidincrement(){this.count++;}}

现在,请看 Vue3 (<script setup>) 的写法:

<script setup>import{ref,computed,onMounted}from'vue';// 1. 成员变量 (ref = private field)constcount=ref(0);// 2. 初始化 (onMounted = PostConstruct)onMounted(()=>{console.log("初始化...");});// 3. Getter 方法 (computed)constdoubleCount=computed(()=>count.value*2);// 4. 公共方法 (function = method)constincrement=()=>{count.value++;// 注意:JS里修改引用类型要用 .value};</script>

发现了吗?完全一一对应!
Vue3 终于允许我们将相关的变量和方法写在一起了,这就是“高内聚” (High Cohesion)


🧱 进阶:Hooks 就是 Service 层

后端开发最讲究分层架构。Controller 负责接收请求,Service 负责业务逻辑。
在 Vue2 时代,逻辑很难复用(Mixins 是噩梦)。
但在 Vue3 中,我们可以把复杂的逻辑抽离成Hooks (Composables)

请大声跟我念:Composables 就是前端的 Service 类!

场景:我们需要在多个页面实现“获取用户信息”的功能。

1. 定义 Service (UserHook.js)

这就像你写了一个UserService.java

// useUser.jsimport{ref,onMounted}from'vue';import{fetchUserApi}from'./api';// 导出这个“Service”exportfunctionuseUser(){// State (DTO)constuserInfo=ref(null);constloading=ref(false);// Method (Service Logic)constgetUser=async(id)=>{loading.value=true;try{userInfo.value=awaitfetchUserApi(id);}finally{loading.value=false;}};// 暴露给外部调用的接口 (Public Interface)return{userInfo,loading,getUser};}

2. 注入 Service (UserProfile.vue)

这就像在 Controller 里@Autowired注入 Service。

<script setup>// 引入 Serviceimport{useUser}from'./hooks/useUser';// 依赖注入 (Dependency Injection)const{userInfo,loading,getUser}=useUser();// 调用方法onMounted(()=>{getUser(1001);});</script><template><div v-if="loading">加载中...</div><div v-else>你好,{{userInfo?.name}}</div></template>

架构图解:

Hook内部逻辑
调用
定义状态
定义行为
监听变化
返回
Ref / Reactive 数据
Composable / Service
Function 方法
Watch / Computed
Vue 组件 / Controller
暴露给组件的对象

⚠️ 后端转 Vue3 的两个“坑”

虽然思想互通,但语法细节上有两个坑,后端同学最容易踩:

1.ref还是reactive?(包装类 vs 原生对象)
  • ref:就像 Java 的IntegerString包装类。它能包装基本类型,也能包装对象。访问值必须加.value
    • 建议:无脑用ref,虽然多写个.value,但更安全,不会丢失响应性。
  • reactive:就像 Java 的 POJO 对象。不需要.value
    • :如果你解构它 (const { name } = person), 响应性就丢了(这就好比把对象里的字段复制给了个临时变量,改临时变量不影响原对象)。
2. 生命周期(Hook 方法)

别去背beforeCreatecreated了。
<script setup>中:

  • 代码直接写在根作用域=created(构造函数体)。
  • onMounted=@PostConstruct(DOM 渲染完后执行,类似 Bean 初始化完成)。
  • onUnmounted=@PreDestroy(组件销毁前,做清理工作)。

📝 总结

Vue3 Composition API 的本质,就是把前端开发从“填空题” (Options API)变成了“写作文” (Script Setup)

对于后端开发者来说,你只需要转变一个观念:

  • 组件 (Component)=类 (Class)
  • Ref 数据=私有字段 (Private Fields)
  • Function=方法 (Methods)
  • Composable=Service 服务类

掌握了这个心法,你会发现 Vue3 的代码结构比 Spring Boot 还要清爽。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/2 2:30:00

桌宠交互性能优化实战:如何解决触摸延迟与动画卡顿问题

桌宠交互性能优化实战&#xff1a;如何解决触摸延迟与动画卡顿问题 【免费下载链接】VPet 虚拟桌宠模拟器 一个开源的桌宠软件, 可以内置到任何WPF应用程序 项目地址: https://gitcode.com/GitHub_Trending/vp/VPet 在虚拟宠物应用中&#xff0c;触摸反馈的即时性和动画…

作者头像 李华
网站建设 2026/4/24 18:25:21

Zotero AI插件终极指南:3分钟快速部署智能文献助手

Zotero AI插件终极指南&#xff1a;3分钟快速部署智能文献助手 【免费下载链接】papersgpt-for-zotero Zotero chat PDF with DeepSeek, GPT, ChatGPT, Claude, Gemini 项目地址: https://gitcode.com/gh_mirrors/pa/papersgpt-for-zotero 还在为海量学术文献感到头疼吗…

作者头像 李华
网站建设 2026/4/21 14:48:09

学生党最爱省钱爱创猫AI APP

外卖点出大餐感&#xff0c;网购省出新高度&#xff1a;学生党的精打细算实战手册每个月末&#xff0c;看着账单上那些不起眼的外卖订单和购物记录&#xff0c;是不是总感觉钱不知不觉就“蒸发”了&#xff1f;一杯奶茶、一次凑单、一个“限时秒杀”&#xff0c;积少成多&#…

作者头像 李华
网站建设 2026/5/1 10:40:28

将PDF转化为RAG文件,进行数据清洗

在本地 RAG 系统中使用 Marker&#xff1a;高精度 PDF 到 Markdown 的离线开源解决方案&#xff08;2025 更新&#xff09; 在本地 RAG&#xff08;Retrieval-Augmented Generation&#xff09;系统中&#xff0c;PDF 解析质量是决定最终问答准确率的关键&#xff08;Garbage …

作者头像 李华
网站建设 2026/4/23 9:29:22

Linux内核实时调度:从基础到实战的终极指南

Linux内核实时调度&#xff1a;从基础到实战的终极指南 【免费下载链接】linux-insides-zh Linux 内核揭秘 项目地址: https://gitcode.com/gh_mirrors/li/linux-insides-zh 在当今的嵌入式系统和工业自动化领域&#xff0c;实时性已成为系统设计的核心考量。你是否曾面…

作者头像 李华
网站建设 2026/4/25 2:10:27

大数据领域数据治理的核心要点与实践策略

大数据领域数据治理的核心要点与实践策略 1. 引入与连接 1.1 引人入胜的开场 在当今数字化时代&#xff0c;数据就如同石油一般&#xff0c;是企业和社会发展的重要资源。想象一下&#xff0c;一家大型电商企业&#xff0c;每天都能收集到海量的数据&#xff0c;包括用户的浏览…

作者头像 李华