快速集成React Native到現有原生應用(Android版)

# 快速集成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 版本即可!

?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,936評論 6 535
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,744評論 3 421
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,879評論 0 381
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,181評論 1 315
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,935評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,325評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,384評論 3 443
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,534評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,084評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,892評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,067評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,623評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,322評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,735評論 0 27
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,990評論 1 289
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,800評論 3 395
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,084評論 2 375

推薦閱讀更多精彩內容