news 2026/5/13 4:33:35

后端开发也能搞定 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/9 2:01:11

gLabels-Qt:简单易用的跨平台标签设计完整指南

gLabels-Qt&#xff1a;简单易用的跨平台标签设计完整指南 【免费下载链接】glabels-qt gLabels Label Designer (Qt/C) 项目地址: https://gitcode.com/gh_mirrors/gl/glabels-qt 你是否曾经为批量打印标签而烦恼&#xff1f;无论是产品标签、名片制作还是库存管理&…

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

Spring Boot统一异常处理

在Spring Boot中实现统一异常处理主要通过ControllerAdvice和ExceptionHandler注解组合完成。这种方式能集中处理控制器层抛出的异常&#xff0c;避免在每个方法中重复编写异常处理代码。 基础实现步骤 创建全局异常处理类并添加ControllerAdvice注解。这个类可以包含多个异常…

作者头像 李华
网站建设 2026/5/11 11:27:17

卡牌游戏(Java/python/JavaScript/C/C++)

小明正在尝试一种新的牌游戏。游戏规则只如下:首先&#xff0c;小明拿到一张写有数字m的牌。 然后&#xff0c;他会拿到另外n张牌&#xff0c;上面分别写有不同的数字&#xff0c;牌排成一排。小明的目标是从这排牌中找到一串连续的牌&#xff0c;这些牌上数字的总和可以被 m整…

作者头像 李华
网站建设 2026/5/9 2:47:43

Foundation 模态框

Foundation 模态框&#xff08;Reveal / Modal&#xff09;详解&#xff08;超级完整版&#xff0c;一次讲透&#xff09; 我们继续你的 Foundation 系列&#xff0c;今天把 模态框&#xff08;Reveal&#xff09;讲得明明白白&#xff01;Foundation 6 中的 Reveal 是最强大的…

作者头像 李华
网站建设 2026/5/11 3:06:33

Vim光标移动效率革命:EasyMotion与Sneak终极对决

Vim光标移动效率革命&#xff1a;EasyMotion与Sneak终极对决 【免费下载链接】vim-galore :mortar_board: All things Vim! 项目地址: https://gitcode.com/gh_mirrors/vi/vim-galore 还在为Vim中缓慢的光标移动而苦恼&#xff1f;今天我们将深入对比两款改变游戏规则的…

作者头像 李华