React Native 与 Expo

时间:2025-05-14 20:39:48

???? Expo 和 React Native 的关系

项目 定义
React Native 一个由 Meta(Facebook)开发的原生移动端开发框架,使用 JavaScript + React 来构建 iOS 和 Android 应用
Expo 一个构建在 React Native 之上的开发工具链,封装了很多复杂配置,提供快速启动、构建和测试能力

???? 简而言之:Expo 是 React Native 的“增强套件”,它使用 React Native 做底层,但封装了一整套开发体验。


???? Expo 提供了什么?

Expo = React Native + 工具链 + 原生 SDK 封装 + 构建服务:

能力 是否 RN 自带 是否 Expo 提供 说明
快速开发脚手架 npx create-expo-app 类似 create-react-app,一键生成项目
OTA 热更新 ✅ Expo Go / Updates 支持原生 App 不发版也能更新 JavaScript
Expo Go App ✅ App Store/Google Play 提供 用于扫码快速预览应用
打包与发布(构建) expo build 或 EAS 免配置构建 iOS/Android 包
封装原生模块(如相机) 需要配置原生代码 ✅ 一行命令即可使用 expo-camera, expo-location
不依赖 Android Studio 初学者友好

???? 两者的关键区别

项目层面 React Native Expo
上手难度 中等(需配置 Xcode/Gradle) 简单,零配置即可开发
自定义原生模块 ✅(但需手动配置) ❌(在 Managed 模式下不支持)
适合初学者 不够友好 ✅ 极度适合初学者使用
发布到商店 需手动构建和签名 可用 eas build 远程构建 + 签名 + 热更新
依赖平台工具链 Managed 模式下几乎不需要

???? 使用关系图

             ┌────────────────────────┐
             │      React Native      │ ← 核心运行时框架(Meta 维护)
             └────────┬───────────────┘
                      │
                      ▼
             ┌────────────────────────┐
             │         Expo           │ ← 开发体验套件(Expo 团队维护)
             └────────────────────────┘

✅ 总结建议

你是… 推荐选项 原因
初学者/中小项目 Expo 零配置、快速预览、支持 OTA 更新
需要自定义原生模块 裸 RNExpo Ejected 模式 更强的灵活性
构建发布要全自动 Expo + EAS Build 支持云构建、免配 Xcode 和 Android Studio