亲测React Native(v0.72)之macOS环境搭建

React Native ( 简称 RN ) 是 Facebook 于2015年4月开源的跨平台移动应用开发框架,是 Facebook 早先开源的 JS 框架 React 在原生移动应用平台的衍生产物,支持 iOS 和 Android 两大平台。RN 使用Javascript 语言,因此熟悉 Web 前端开发的技术人员,只需很少的学习就可以进入移动应用开发领域。

注意

  • 在 Windows 下,只能搭建开发安卓应用的环境。而不能搭建开发苹果应用的环境
  • 在 Mac 下,既可以搭建安卓应用的环境,又可以搭建开发苹果应用的环境

Node.js安装

下载Node:nodejs.org/en

安装之后可以切换国内的npm镜像源使用nrm配置

已经安装了 Node,请检查其版本是否在 v16 以上。

Yarn安装

yarn 是 Facebook 提供的替代 npm 的工具,可以加速 node 模块的下载。

js 复制代码
npm install -g yarn

Watchman

Watchman则是由 Facebook 提供的监视文件系统变更的工具。安装此工具可以提高开发时的性能(packager 可以快速捕捉文件的变化从而实现实时刷新)。

推荐使用Homebrew来安装 Watchman。

js 复制代码
brew install watchman

Xcode

React Native 目前需要Xcode 12 或更高版本。你可以通过 App Store 或是到Apple 开发者官网上下载。这一步骤会同时安装 Xcode IDE、Xcode 的命令行工具和 iOS 模拟器。

CocoaPods

CocoaPods是用 Ruby 编写的包管理器(可以理解为针对 iOS 的 npm)。从 0.60 版本开始 react native 的 iOS 版本需要使用 CocoaPods 来管理依赖。你可以使用下面的命令来安装 CocoaPods。CocoaPods 的版本需要 1.10 以上。

js 复制代码
brew install cocoapods

macOS默认ruby版本:

可能会出现的问题:

了解了一下之后,CocoaPods这个东西是基于ruby gem的,换源:

js 复制代码
gem sources --add https://gems.ruby-china.com/ --remove https://rubygems.org/
gem sources -l

创建工程

如果你之前全局安装过旧的react-native-cli命令行工具,请使用npm uninstall -g react-native-cli卸载掉它以避免一些冲突:

js 复制代码
npm uninstall -g react-native-cli @react-native-community/cli

使用 React Native 内建的命令行工具来创建一个名为"AwesomeProject"的新项目。这个命令行工具不需要安装,可以直接用 node 自带的npx命令来使用(注意 init 命令默认会创建最新的版本)

js 复制代码
npx react-native@latest init AwesomeProject

不要在目录、文件名中使用中文、空格等特殊符号。请不要单独使用常见的关键字作为项目名(如 class, native, new, package 等等)。请不要使用与核心模块同名的项目名(如 react, react-native 等)。

在你的项目目录中运行yarn ios或者yarn react-native run-ios:

js 复制代码
cd AwesomeProject
yarn ios
# 或者
yarn react-native run-ios

此命令会对项目的原生部分进行编译,同时在另外一个命令行中启动Metro服务对 js 代码进行实时打包处理(类似 webpack)。Metro服务也可以使用yarn start命令单独启动。

提示:如果此命令无法正常运行,请使用 Xcode 运行来查看具体错误(run-ios 的报错没有任何具体信息)。注意 0.60 版本之后的主项目文件是.xcworkspace,不是.xcodeproj

很快就应该能看到 iOS 模拟器自动启动并运行你的项目。

在正常编译完成后,开发期间请保持Metro命令行窗口运行而不要关闭。以后需要再次运行项目时,如果没有修改过 ios 目录中的任何文件,则只需单独启动yarn start命令。如果对 ios 目录中任何文件有修改,则需要再次运行yarn ios命令完成原生部分的编译。

参考资料

  1. www.react-native.cn/docs/enviro...
  2. blog.csdn.net/qq_41391628...
  3. blog.csdn.net/weixin_4522...
  4. blog.csdn.net/PianZhideNa...
相关推荐
2601_955767423 小时前
观复盾 iPhone 17 Pro 护景贴深度评测:参数解析与实测避坑
人工智能·ios·ar·iphone·圆偏振光·磁控溅射
一拳一个娘娘腔4 小时前
【SRC漏洞挖掘系列】第11期:移动端安全(Android/iOS)—— APP 里的“猫腻”大起底
android·安全·ios
学习3人组5 小时前
IOS手机使用电脑代理 IP 作为网关/代理出口实现穿越上网
tcp/ip·ios·智能手机
沙漠5 小时前
React Native-SyncFormatEdittext:用 JSI 实现零闪烁的实时文本格式化
前端·react native
2501_915106326 小时前
深入解析HTTPS抓包原理、中间人攻击及反抓包技术攻防
数据库·网络协议·ios·小程序·https·uni-app·iphone
ch_ziyuan6 小时前
跨平台APP封装分发系统搭建:iOS免签+安卓防报毒+IPA签名一体化
android·ios
游戏开发爱好者86 小时前
React Grab工具详解:AI助力Vue3、Svelte和Solid前端元素调试
android·ios·小程序·https·uni-app·iphone·webview
UXbot6 小时前
初创公司如何选择合适的UI工具支撑快速迭代产品?
人工智能·低代码·ios·交互·原型模式
CodeForCoffee7 小时前
iPhone照片导入Mac
macos·ios·iphone
Digitally7 小时前
如何将数据从传音(TECNO)手机迁移到 iPhone?
ios·智能手机·iphone