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

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

前置约定

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

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

编译对照

Vue useAttrs() → React props 引用

useAttrs 是 Vue 3 中用于获取未在 defineProps 中声明的透传属性的 API。在 React 中,所有属性都统一通过 props 传递,因此 VuReact 会将 useAttrs() 编译为对 props 的引用。

小提示:若组件未声明任何 props,VuReact 会自动补全组件参数 propsprops: Record<string, unknown>

  • Vue 代码:
html 复制代码
<script setup lang="ts">
  const attrs = useAttrs();
</script>
  • VuReact 编译后 React 代码:
tsx 复制代码
const attrs = props as Record<string, unknown>;

从示例可以看到:Vue 的 useAttrs() 被编译为 React 中对 props 的直接引用。VuReact 会保留 useAttrs 的运行时含义,同时将其与 React 的 Props 机制自然对接。

Vue useAttrs() 与 TypeScript 类型处理

VuReact 会根据场景自动补齐 useAttrs() 的类型信息,确保 React 端类型提示正常。

  • Vue 代码:
html 复制代码
<script setup lang="ts">
  interface Attrs {
    class?: string;
    style?: string;
    [key: string]: unknown;
  }
  const attrs = useAttrs();
  const { style, class: cls } = useAttrs() as Attrs;
  const typeAnnotation: Attrs = useAttrs();
</script>
  • VuReact 编译后 React 代码:
tsx 复制代码
interface Attrs {
  class?: string;
  style?: string;
  [key: string]: unknown;
}
const attrs = props as Record<string, unknown>;
const { style, class: cls } = props as Attrs;
const typeAnnotation = props as Attrs;

VuReact 会在可用时对 useAttrs() 添加类型断言或保留显式注解,从而让 React 中的 attrs 访问保持类型安全。

Vue useAttrs() 在纯 JavaScript 场景

在纯 JavaScript 环境中,VuReact 会将 useAttrs() 直接替换为对 props 的引用。

  • Vue 代码:
html 复制代码
<script setup>
  const attrs = useAttrs();
</script>
  • VuReact 编译后 React 代码:
ts 复制代码
const attrs = props;

这意味着在 JS 场景下,attrs 仍然是 React 组件接收的 props 对象,行为上与 Vue 的透传属性访问保持一致。

相关资源

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

相关推荐
马士兵教育2 小时前
AI工作岗位的就业分层?
开发语言·人工智能·学习·面试·职场和发展
yusirxiaer2 小时前
为什么 markRaw 能修复 Vue 3 + ECharts 的 resize 报错
javascript·vue.js·echarts
我叫黑大帅2 小时前
Go 项目中 Redis 缓存的实用设计与实现(Cache-Aside 模式)
redis·后端·面试
赛博切图仔3 小时前
前端性能内卷终点?Signals 正在重塑我们的开发习惯
前端·javascript·vue.js
zjeweler3 小时前
“网安+护网”终极300多问题面试笔记-1共3-内网&域相关
笔记·web安全·网络安全·面试·职场和发展·护网面试
一 乐4 小时前
饮食营养信息|基于springboot + vue饮食营养管理信息平台系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·饮食营养管理信息系统
军军君014 小时前
数字孪生监控大屏实战模板:空气污染监控
前端·javascript·vue.js·typescript·前端框架·echarts·数字孪生
练习前端两年半4 小时前
Vue3 KeepAlive 深度揭秘:组件缓存的魔法是如何实现的?
前端·vue.js·面试
Raink老师4 小时前
【AI面试临阵磨枪】OpenClaw 与 LangChain、AutoGPT、MetaGPT 的本质区别是什么?
人工智能·面试·langchain·ai 面试·ai 应用开发面试