news 2026/6/10 17:24:46

后端开发也能搞定 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/6/9 17:45:02

GHOST误操作致分区消失?一招教你找回丢失数据

在数据备份与恢复的领域里&#xff0c;GHOST作为一款曾经广泛使用的系统备份与还原工具&#xff0c;为众多用户带来了便利。然而&#xff0c;不当的操作或误选选项&#xff0c;有时会导致意想不到的后果——比如&#xff0c;原本多分区存储的数据&#xff0c;在GHOST操作后&…

作者头像 李华
网站建设 2026/6/10 10:28:15

前端剪贴板功能实现方案:从零到一的完整技术指南

前端剪贴板功能实现方案&#xff1a;从零到一的完整技术指南 【免费下载链接】clipboard.js :scissors: Modern copy to clipboard. No Flash. Just 3kb gzipped :clipboard: 项目地址: https://gitcode.com/gh_mirrors/cl/clipboard.js 前端剪贴板功能在现代Web应用中扮…

作者头像 李华
网站建设 2026/6/9 23:33:41

亲测!专业机油批发的实践与成果

亲测&#xff01;专业机油批发的实践与成果引言在汽车后市场中&#xff0c;机油批发业务具有广阔的发展前景。四川小江军作为一家专注于机油领域的品牌&#xff0c;在专业机油批发方面有着丰富的实践经验和显著的成果。本文将结合亲测体验&#xff0c;探讨专业机油批发的实践要…

作者头像 李华
网站建设 2026/6/10 10:26:27

如何用字节跳动开源AI助手让工作效率翻倍?

如何用字节跳动开源AI助手让工作效率翻倍&#xff1f; 【免费下载链接】UI-TARS-2B-SFT 项目地址: https://ai.gitcode.com/hf_mirrors/ByteDance-Seed/UI-TARS-2B-SFT 还在为重复的电脑操作烦恼吗&#xff1f;每天花费大量时间在Excel数据处理、邮件整理、文件归档上&…

作者头像 李华
网站建设 2026/6/9 23:42:45

智慧园区系统:技术赋能下的园区管理革新与价值升级

在数字经济加速渗透的今天&#xff0c;智慧园区系统已成为破解传统园区管理瓶颈、激活产业发展动能的核心支撑。它不再是简单的技术叠加&#xff0c;而是集数据整合、智能管控、服务优化于一体的综合性管理生态&#xff0c;通过融合大数据、物联网、云计算、人工智能等前沿技术…

作者头像 李华