跳到主要内容
版本:0.78

React Native Gradle 插件

本指南描述了在为 Android 构建你的 React Native 应用时,如何配置 React Native Gradle Plugin(通常简称为 RNGP)。

使用插件

React Native Gradle Plugin 作为单独的 NPM 包分发,该包会随 react-native 自动安装。

对于使用 npx react-native init 创建的新项目,该插件已经配置好。如果你使用此命令创建应用,无需执行任何额外步骤来安装它。

如果你要将 React Native 集成到现有项目中,请参考相应页面:其中包含如何安装插件的具体说明。

配置插件

默认情况下,插件将开箱即用,具有合理的默认值。你应该参考本指南,仅在需要时自定义行为。

要配置插件,你可以修改 android/app/build.gradle 中的 react 块:

groovy
apply plugin: "com.facebook.react"

/**
* 这是用于自定义你的 React Native Android 应用的配置块。
* 默认情况下你不需要应用任何配置,只需取消注释你需要的行。
*/
react {
// 自定义配置放在这里。
}

每个配置键如下所述:

root

这是你的 React Native 项目的根文件夹,即 package.json 文件所在的位置。默认是 ..。你可以按如下方式自定义:

groovy
root = file("../")

reactNativeDir

这是 react-native 包所在的文件夹。默认是 ../node_modules/react-native。 如果你在 monorepo 中或使用不同的包管理器,你可以调整 reactNativeDir 以适应你的设置。

你可以按如下方式自定义:

groovy
reactNativeDir = file("../node_modules/react-native")

codegenDir

这是 react-native-codegen 包所在的文件夹。默认是 ../node_modules/react-native-codegen。 如果你在 monorepo 中或使用不同的包管理器,你可以调整 codegenDir 以适应你的设置。

你可以按如下方式自定义:

groovy
codegenDir = file("../node_modules/@react-native/codegen")

cliFile

这是 React Native CLI 的入口文件。默认是 ../node_modules/react-native/cli.js。 需要入口文件,因为插件需要调用 CLI 来进行打包和创建应用。

如果你在 monorepo 中或使用不同的包管理器,你可以调整 cliFile 以适应你的设置。 你可以按如下方式自定义:

groovy
cliFile = file("../node_modules/react-native/cli.js")

debuggableVariants

这是可调试变体的列表(有关变体的更多上下文,请参阅使用变体)。

默认情况下,插件仅将 debug 视为 debuggableVariants,而 release 不是。如果你有其他变体(如 staginglite 等),你需要相应地调整此项。

列为 debuggableVariants 的变体不会附带打包好的 bundle,因此你需要 Metro 来运行它们。

你可以按如下方式自定义:

groovy
debuggableVariants = ["liteDebug", "prodDebug"]

nodeExecutableAndArgs

这是应为所有脚本调用的 node 命令和参数列表。默认是 [node],但可以自定义以添加额外标志,如下所示:

groovy
nodeExecutableAndArgs = ["node"]

bundleCommand

这是创建应用 bundle 时要调用的 bundle 命令的名称。如果你使用 RAM Bundles,这很有用。默认是 bundle,但可以自定义以添加额外标志,如下所示:

groovy
bundleCommand = "ram-bundle"

bundleConfig

这是配置文件的路径,如果提供,将传递给 bundle --config <file>。默认为空(不提供配置文件)。有关打包配置文件的更多信息,可以在 CLI 文档 中找到。可按如下方式自定义:

groovy
bundleConfig = file(../rn-cli.config.js)

bundleAssetName

这是应生成的 bundle 文件的名称。默认是 index.android.bundle。可按如下方式自定义:

groovy
bundleAssetName = "MyApplication.android.bundle"

entryFile

用于生成 bundle 的入口文件。默认是搜索 index.android.jsindex.js。可按如下方式自定义:

groovy
entryFile = file("../js/MyApplication.android.js")

extraPackagerArgs

将传递给 bundle 命令的额外标志列表。可用标志列表在 CLI 文档 中。默认为空。可按如下方式自定义:

groovy
extraPackagerArgs = []

hermesCommand

hermesc 命令(Hermes 编译器)的路径。React Native 自带了一个版本的 Hermes 编译器,所以你通常不需要自定义此项。默认情况下,插件将为你的系统使用正确的编译器。

hermesFlags

传递给 hermesc 的标志列表。默认是 ["-O", "-output-source-map"]。你可以按如下方式自定义

groovy
hermesFlags = ["-O", "-output-source-map"]

使用 Flavor 与构建变体

在构建 Android 应用时,你可能想要使用 自定义 flavor 以便从同一个项目开始拥有不同版本的应用。

请参考 官方 Android 指南 来配置自定义构建类型(如 staging)或自定义 flavor(如 fulllite 等)。 默认情况下,新应用创建时带有两种构建类型(debugrelease),没有自定义 flavor。

所有构建类型和所有 flavor 的组合生成一组 构建变体。例如,对于 debug/staging/release 构建类型和 full/lite,你将拥有 6 个构建变体:fullDebugfullStagingfullRelease 等等。

如果你使用 debugrelease 之外的自定义变体,你需要指示 React Native Gradle 插件,使用 debuggableVariants 配置指定哪些变体是 可调试的,如下所示:

diff
apply plugin: "com.facebook.react"

react {
+ debuggableVariants = ["fullStaging", "fullDebug"]
}

这是必要的,因为插件将跳过所有 debuggableVariants 的 JS 打包:你需要 Metro 来运行它们。例如,如果你在 debuggableVariants 中列出了 fullStaging,你将无法将其发布到商店,因为它将缺少 bundle。

插件底层在做什么?

React Native Gradle Plugin 负责配置你的应用构建,以便将 React Native 应用发布到生产环境。 该插件还用于第三方库中,以运行用于新架构的 Codegen

以下是插件职责的摘要:

  • 为每个非可调试变体添加一个 createBundle<Variant>JsAndAssets 任务,负责调用 bundlehermesccompose-source-map 命令。
  • 设置正确版本的 com.facebook.react:react-androidcom.facebook.react:hermes-android 依赖,从 react-nativepackage.json 中读取 React Native 版本。
  • 设置正确的 Maven 仓库(Maven Central、Google Maven Repo、JSC local Maven repo 等),以便使用所有必要的 Maven 依赖。
  • 设置 NDK 以便你构建使用新架构的应用。
  • 设置 buildConfigFields,以便你可以在运行时知道 Hermes 或新架构是否启用。
  • 将 Metro DevServer 端口设置为 Android 资源,以便应用知道连接到哪个端口。
  • 如果库或应用使用新架构的 Codegen,则调用 React Native Codegen