美文网首页
快速集成React Native到现有原生应用(Android版

快速集成React Native到现有原生应用(Android版

作者: Yasin27878 | 来源:发表于2018-12-14 11:21 被阅读29次

# 快速集成React Native到现有原生应用(Android版)

## 一.官方集成流程

把 React Native 组件集成到 Android 应用中有如下几个主要步骤:

- 配置好 React Native 依赖和项目结构。

- 创建 js 文件,编写 React Native 组件的 js 代码。

- 在应用中添加一个RCTRootView。这个RCTRootView正是用来承载你的 React Native 组件的容器。

- 启动 React Native 的 Packager 服务,运行应用。

- 验证这部分组件是否正常工作。

这个流程不够通用,集成流程过于复杂,,,,,,所以,写了rn的runtime,集成即可食用

##  二.开发环境准备

### 1. 开发环境准备

#### 安装依赖

必须安装的依赖有:Node、Watchman 和 React Native 命令行工具以及 JDK 和 Android Studio。

#####  1.Node, Watchman

我们推荐使用Homebrew来安装 Node 和 Watchman。在命令行中执行下列命令安装

```

brew install node

brew install watchman

```

Node,需要在 v8.3 以上

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

##### 2.Yarn、React Native 的命令行工具(react-native-cli)

Yarn是 Facebook 提供的替代 npm 的工具,可以加速 node 模块的下载。React Native 的命令行工具用于执行创建、初始化、更新项目、运行打包服务(packager)等任务

```

npm install -g yarn react-native-cli

```

##### 3.JDK、Android Studio的安装

更多更详细搭建流程 [https://reactnative.cn/docs/getting-started.html](https://reactnative.cn/docs/getting-started.html)

### 2. 配置项目目录结构

首先创建一个空目录用于存放 React Native 项目,然后在其中创建一个/android子目录,把你现有的 Android 项目拷贝到/android子目录中。

### 3.安装 JavaScript 依赖包

- 1) 在项目根目录下创建一个名为package.json的空文本文件,然后填入以下内容:

```

{

  "name": "YReactNativeApp",

  "version": "0.0.1",

  "private": true,

  "scripts": {

    "start": "node node_modules/react-native/local-cli/cli.js start"

  }

}

```

注: 示例中的version字段没有太大意义(除非你要把你的项目发布到 npm 仓库)。scripts中是用于启动 packager 服务的命令。

- 2) 接下来我们使用 yarn 或 npm(两者都是 node 的包管理器)来安装 React 和 React Native 模块。请打开一个终端/命令提示行,进入到项目目录中(即包含有 package.json 文件的目录),然后运行下列命令来安装:

```

$ yarn add react-native

```

这样默认会安装最新版本的 React Native,同时会打印出类似下面的警告信息(你可能需要滚动屏幕才能注意到):

```

warning "react-native@0.52.2" has unmet peer dependency "react@16.2.0".

```

这是正常现象,意味着我们还需要安装指定版本的 React:

```

  yarn add react@16.2.0

```

注意必须严格匹配警告信息中所列出的版本,高了或者低了都不可以。

如果你使用多个第三方依赖,可能这些第三方各自要求的 react 版本有所冲突,此时应优先满足react-native所需要的react版本。其他第三方能用则用,不能用则只能考虑选择其他库。

所有 JavaScript 依赖模块都会被安装到项目根目录下的node_modules/目录中(这个目录我们原则上不复制、不移动、不修改、不上传,随用随装)。

  把node_modules/目录记录到.gitignore文件中(即不上传到版本控制系统,只保留在本地)。

### 4. YRuntime 快速集成

#### 1.在项目的 build.gradle 文件中为 React Native 添加一个 maven 依赖的入口,必须写在 "allprojects" 代码块中:

在你的 app 中 build.gradle 文件中添加 React Native 依赖:

```

allprojects {

    repositories {

        maven {

            // All of React Native (JS, Android binaries) is installed from npm

            url "$rootDir/../node_modules/react-native/android"

        }

        ...

    }

    ...

}

```

确保依赖路径的正确!以免在 Android Studio 运行 Gradle 同步构建时抛出 “Failed to resolve: com.facebook.react:react-native:0.x.x" 异常。

#### 2.集成Yruntime到项目

在项目中引用

```

implementation 'cn.yasin:yruntime:1.0.0'

```

#### 3.测试集成结果

##### 1. 运行 Packager

运行应用首先需要启动开发服务器(Packager)。你只需在项目根目录中执行以下命令即可:

```

$ yarn start

```

##### 2. 运行你的应用

保持 packager 的窗口运行不要关闭,然后像往常一样编译运行你的 Android 应用(在命令行中执行./gradlew installDebug或是在 Android Studio 中编译运行)。

编译执行一切顺利进行之后,在进入到 YReactActivity 时应该就能立刻从 packager 中读取 JavaScript 代码并执行和显示:

![](https://reactnative.cn/docs/assets/EmbeddedAppAndroid.png)

##### 3. 在 Android Studio 中打包

你也可以使用 Android Studio 来打 release 包!其步骤基本和原生应用一样,只是在每次编译打包之前需要先执行 js 文件的打包(即生成离线的 jsbundle 文件)。具体的 js 打包命令如下:

```

$ react-native bundle --platform android --dev false --entry-file index.js --bundle-output android/com/your-company-name/app-package-name/src/main/assets/index.android.bundle --assets-dest android/com/your-company-name/app-package-name/src/main/res/

```

注意把上述命令中的路径替换为你实际项目的路径。如果 assets 目录不存在,则需要提前自己创建一个。

然后在 Android Studio 中正常生成 release 版本即可!

相关文章

网友评论

      本文标题:快速集成React Native到现有原生应用(Android版

      本文链接:https://www.haomeiwen.com/subject/pyfirftx.html