你的 Vue 3 defineProps(),VuReact 会编译成什么样的 React?

VuReact 是一个能将 Vue 3 代码编译为标准、可维护 React 代码的工具。今天就带大家直击核心:Vue 中常见的 defineProps 宏经过 VuReact 编译后会变成什么样的 React 代码?

前置约定

为避免示例代码冗余导致理解偏差,先明确两个小约定:

  1. 文中 Vue / React 代码均为核心逻辑简写,省略完整组件包裹、无关配置等内容;
  2. 默认读者已熟悉 Vue 3 中 defineProps 的 API 用法与核心行为。

编译对照

Vue defineProps<{ ... }>() → React props 类型 + props 参数

defineProps 是 Vue 3 <script setup> 中用于声明组件输入属性的宏,它既允许类型参数声明,也支持运行时声明形式。VuReact 会将它编译为 React 中的 props 类型声明,并将组件参数改写为 props

  • Vue 代码:
html 复制代码
<script setup lang="ts">
  const props = defineProps<{ id: string; enabled?: boolean }>();
</script>
  • VuReact 编译后 React 代码:
tsx 复制代码
type ICompProps = {
  id: string;
  enabled?: boolean;
};

const Comp = (props: ICompProps) => {
  // ...
};

从示例可以看到:Vue 的 defineProps 并不会直接编译为某个运行时 Hook,而是转换为 React 中标准的 props 类型和组件参数。VuReact 会将 defineProps 中的类型信息提取为独立的 props 类型定义,保持类型安全与 React 组件 Props 规范一致


Vue defineProps('foo', 'bar') / defineProps({ ... }) → React props 推导

除了类型参数形式,defineProps 还支持数组和对象形式的运行时声明。VuReact 会对这些形式进行类型推导,并在可行的情况下将结果映射到 React 的 props 类型。

  • Vue 代码:
html 复制代码
<script setup>
  const props = defineProps(['foo', 'bar']);
</script>
  • React 输出(示意):
tsx 复制代码
type ICompProps = {
  foo?: any;
  bar?: any;
};

const Comp = (props: ICompProps) => {
  // ...
};

若使用对象形式声明,编译器也会尽量保留类型推导。虽然这两种形式可用,但推荐优先使用类型参数形式,因为它在 React 端的类型提示更清晰、结果更可控。

🔗 相关资源


✨ 如果你觉得本文对你理解 VuReact 有帮助,欢迎点赞、收藏、关注!

相关推荐
Raink老师17 小时前
【AI面试临阵磨枪-79】实时数据 RAG:订单、商家、物流、天气、动态库存
人工智能·面试·职场和发展
Cosolar17 小时前
Chroma向量库面试学习指南
数据库·人工智能·面试·职场和发展·数据库架构
小江的记录本18 小时前
【JVM虚拟机】垃圾回收GC:垃圾收集器:CMS:核心原理、回收流程、优缺点、废弃原因(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·spring·面试·maven
小江的记录本20 小时前
【JVM虚拟机】垃圾回收GC:垃圾回收算法:标记-清除、标记-复制、标记-整理、分代收集(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·算法·安全·面试
小江的记录本21 小时前
【JVM虚拟机】垃圾回收GC:垃圾收集器:G1:Region分区、Mixed GC、回收流程、适用场景(高频)(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·spring·spring cloud·面试
吃乔巴的糖1 天前
Vue 3 打印模板设计器 (print-canvas-designer)
前端·vue.js
Mahir081 天前
MyBatis 深度解密:从执行流程到底层原理全解
java·后端·面试·mybatis
罗超驿1 天前
9.LeetCode 209. 长度最小的子数组 | 滑动窗口专题详解
java·算法·leetcode·面试
折哥的程序人生 · 物流技术专研1 天前
《Java 100 天进阶之路》第35篇:Java异常处理最佳实践
java·开发语言·后端·面试·求职招聘
哈撒Ki1 天前
前端性能优化汇总
前端·面试