环境说明
主机环境:Windows 11 家庭版 21H2 版本主机操作系统版本:22000.348Android Studio 版本:Electric Eel | 2022.1.1 Patch 1Node.JS 版本:v18.6.0JDK 版本:openjdk 11.0.19 2023-04-18App 调试运行环境:HUAWEI HarmonyOS 3.0.0参考:https://reactnative.cn/docs/environment-setup
开发环境配置
必须包含的依赖有 Node、JDK、Android Studio。上述开发环境配置在这里仅作简要阐述,不作详细说明,相关配置问题请查询相关资料。
Node.js
https://nodejs.org/zh-cn
官网下载地址如上,下载对应操作系统安装包安装即可。 推荐安装 Yarn 工具包,在命令行下输入如下指令安装,可代替 npm 功能。
npm install -g yarn
JDK
https://www.oracle.com/java/technologies/downloads/
官网下载地址如上,下载对应操作系统的Java版本并安装,React-Native 推荐使用的版本为11+。安装完成后配置相关环境变量,进入“此电脑-属性-高级系统设置-高级-环境变量”,新建 JAVA_HOME 系统变量,变量值为安装的 jdk 路径,并在 Path 变量中添加如下路径:
%JAVA_HOME%\bin
%JAVA_HOME%\jre\bin
由于在 JDK11 之后 JRE 集成进 JDK 中,如果需要配置 JRE 路径,需要进入 JDK 安装路径下执行下述指令封装专用 JRE 目录:
bin\jlink.exe --module-path jmods --add-modules java.desktop --output jre
Android Studio
https://developer.android.google.cn/studio
官网下载地址如上,下载后安装即可。第一次进入会有相关配置,无特殊需求默认即可。接着会有选择 SDK 安装位置,等待安装并结束。结束后配置环境变量,新建系统变量 ANDROID_HOME,路径选择 SDK 安装位置,然后在 Path 变量中添加如下路径:
%ANDROID_HOME%\platform-tools
%ANDROID_HOME%\emulator
%ANDROID_HOME%\tools
%ANDROID_HOME%\tools\bin
React Native 项目创建
在指定目录中使用 React Native 内建命令行工具创建名为 AwesomeProject 的新项目:
npx react-native init AwesomeProject
如果需要选择指定版本或项目模板可以使用如下指令:
# 指定版本号 需精确到如下版本
npx react-native init AwesomeProject --version X.XX.X
# 指定项目模板 如带 TypeScript 配置版本
npx react-native init AwesomeTSProject --template react-native-template-typescript
编译并运行
进入刚创建的 AwesomeProject 项目目录,即可通过指令编译运行,需要运行模拟器或连接真机调试运行:
yarn android
# 或使用如下指令
yarn react-native run-android
该指令对项目原生部分进行编译,同时在另一个命令行终端中启动 Metro 服务对于 js 代码进行实时打包处理。 Metro 服务可以使用 yarn start 指令单独启动。
项目启动完成即可在模拟器或真机中看到运行的App,在项目中修改App.js并Reload即可看到最新修改。
可能出现的问题
Gradle 下载慢
可选的方案有:
使用更科学的方式下载在项目路径下settings.gradle文件中修改gradle版本使用本地已下载的gradle版本
React Native 依赖下载慢
可选的方案有:
使用更科学的方式下载在项目路径下 build.gradle 文件中添加 aliyun 仓库,阿里云仓库官网地址如下,根据手册添加配置即可:
https://developer.aliyun.com/mvn/guide
配置本地 gradle,在本地 .gradle 路径(默认位置是 C:\Users\用户名\.gradle )中新建一个名为 init.gradle 的文件,内容如下,保存后再次启动 yarn android 即可:
allprojects{
repositories {
def ALIYUN_REPOSITORY_URL = 'https://maven.aliyun.com/repository/central/'
def ALIYUN_JCENTER_URL = 'https://maven.aliyun.com/repository/public/'
all { ArtifactRepository repo ->
if(repo instanceof MavenArtifactRepository){
def url = repo.url.toString()
if (url.startsWith('https://repo1.maven.org/maven2') || url.startsWith('http://repo1.maven.org/maven2')) {
project.logger.lifecycle "Repository ${repo.url} replaced by $ALIYUN_REPOSITORY_URL."
remove repo
}
if (url.startsWith('https://jcenter.bintray.com/') || url.startsWith('http://jcenter.bintray.com/')) {
project.logger.lifecycle "Repository ${repo.url} replaced by $ALIYUN_JCENTER_URL."
remove repo
}
}
}
maven {
url ALIYUN_REPOSITORY_URL
url ALIYUN_JCENTER_URL
url 'https://maven.aliyun.com/repository/google/'
url 'https://maven.aliyun.com/repository/gradle-plugin/'
}
}
buildscript{
repositories {
def ALIYUN_REPOSITORY_URL = 'https://maven.aliyun.com/repository/central/'
def ALIYUN_JCENTER_URL = 'https://maven.aliyun.com/repository/public/'
all { ArtifactRepository repo ->
if(repo instanceof MavenArtifactRepository){
def url = repo.url.toString()
if (url.startsWith('https://repo1.maven.org/maven2') || url.startsWith('http://repo1.maven.org/maven2')) {
project.logger.lifecycle "Repository ${repo.url} replaced by $ALIYUN_REPOSITORY_URL."
remove repo
}
if (url.startsWith('https://jcenter.bintray.com/') || url.startsWith('http://jcenter.bintray.com/')) {
project.logger.lifecycle "Repository ${repo.url} replaced by $ALIYUN_JCENTER_URL."
remove repo
}
}
}
maven {
url ALIYUN_REPOSITORY_URL
url ALIYUN_JCENTER_URL
url 'https://maven.aliyun.com/repository/google/'
url 'https://maven.aliyun.com/repository/gradle-plugin/'
}
}
}
}
参考阅读
发表评论