Vue 转 React:toRaw(),VuReact 怎么处理?

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

前置约定

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

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

编译对照

Vue toRaw() → React useToRaw()

toRaw 是 Vue 3 中用于获取响应式对象原始非响应式引用的 API,通常用于调试、序列化或与非响应式库交互时。VuReact 会将它编译为 useToRaw,让 React 端也能安全地读取原始数据对象。

  • Vue 代码:
html 复制代码
<script setup>
  import { reactive, toRaw } from 'vue';

  const state = reactive({
    settings: {
      theme: 'dark',
      notifications: true,
    },
  });

  const rawData = toRaw(state);
</script>
  • VuReact 编译后 React 代码:
ts 复制代码
import { useReactive, useToRaw } from '@vureact/runtime-core';

const state = useReactive({
  settings: {
    theme: 'dark',
    notifications: true,
  },
});

const rawData = useToRaw(state);

VuReact 提供的 useToRawtoRaw 的适配 API ,可理解为「React 版的 Vue toRaw」,完全模拟 Vue toRaw 的语义------它返回的是原始对象引用,且该对象不再具有响应性,修改它不会触发视图更新。


🔗 相关资源


📖 继续阅读


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

相关推荐
z19408920661 小时前
微软语音识别失败原因排查:从上传到获取文本的完整指南
前端·经验分享·语音识别
久爱@勿忘1 小时前
uniappH5跳转小程序
前端·小程序·uni-app
蒋胜山4 小时前
Excel 练习题(5)
经验分享·excel
布局呆星4 小时前
Vue Router :基础使用与嵌套路由实战
前端·javascript·vue.js
小码哥_常10 小时前
安卓开发秘籍:解锁10大性能优化秘诀
前端
AI人工智能+电脑小能手11 小时前
【大白话说Java面试题】【Java基础篇】第15题:JDK1.7中HashMap扩容为什么会发生死循环?如何解决
java·开发语言·数据结构·后端·面试·哈希算法
谁呛我名字11 小时前
JavaScript 类型转换与运算规则
javascript
try2find11 小时前
打印ascii码报错问题
java·linux·前端
郑州光合科技余经理11 小时前
同城O2O海外版二次开发实战:从支付网关到配送算法
开发语言·前端·后端·算法·架构·uni-app·php