React-native初體驗(安卓篇)

来源:http://www.cnblogs.com/zhuanzhuanfe/archive/2017/07/20/7213844.html
-Advertisement-
Play Games

本篇文章主要包括兩方面,如何從0開始把RN(react-native)項目整合進入現有Android項目,以及我們做的第一個RN的上線項目遇到的一些坑。 初次做RN項目,我們選擇做了一個邏輯相對簡單的轉轉app內部的幫助中心項目。整個項目有4個頁面用的RN,其他頁面走的是native提供的統跳協議, ...


本篇文章主要包括兩方面,如何從0開始把RN(react-native)項目整合進入現有Android項目,以及我們做的第一個RN的上線項目遇到的一些坑。

 

初次做RN項目,我們選擇做了一個邏輯相對簡單的轉轉app內部的幫助中心項目。整個項目有4個頁面用的RN,其他頁面走的是native提供的統跳協議,跳轉到對應的native頁面或者是H5頁面。

 

整合RN到android項目中

react-native cli提供的init指令,可以幫助我們創建一個RN的工程,但是很多場景下RN都是移植進入原生android或者iOS中。例如應該如何實現,在Android頁面,點擊一個按鈕進入RN頁面呢?

 

下麵是具體的實現過程。

 

 

1、新建一個Android項目

 

註意Minimum SDK選擇API23以上,一路next後finish。

 

2、添加JS

打開studio的Terminal視窗,輸入如下命令:

npm init
會讓你輸入一些初始化package.json 的配置信息,例如:

 

 

按照提示輸入就行了。
這一步完成之後,在項目的根目錄下就會生成package.json這個文件,下一步輸入:

 

npm install [email protected] - -save
npm install react-native@^0.44.0 - -save

註意,一定優先安裝react哦

 

大約一兩分鐘的樣子(如果卡到這裡了,看看安裝時是不是忘了配置鏡像),完成之後你的根目錄下會多了一個node_modules的文件夾,裡面存放了下載好的React 和React Native。這裡有童鞋可能會質疑為什麼不把react和react-native的依賴直接寫入package.json中,然後直接npm install,如果這麼做的化,npm run start啟動的時候會報如下的錯誤:

 

接下來把如下命令粘貼到package.json 文件下 scripts 標簽中

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

下一步,在根目錄下創建index.android.js文件並把如下代碼粘貼到其中:

 

 

代碼很簡單,居中顯示一個HelloWorld。

 

3、項目配置(Android)

用android studio打開工程,修改android根目錄下Gradle Scripts的build.gradle(Module:app)文件添加如下內容,註意下麵appcompat-v7版本為25.2.0,而且我把dependencies中test相關的依賴移除掉了,避免不必要的bug。

 

 

 

在build.gradle(Project:***)中添加依賴

 

 

繼續下一步,在AndroidManifest.xml中添加網路訪問許可權

 

4、創建Activity

以下幾步不要安裝官網的去做,官網的步驟太麻煩,而且很久沒有更新了。

1.新建一個Activity,讓其繼承ReactActivity,並重寫getMainComponentName(),返回我們在index.android.js中註冊的HelloWorld這個組件。

 

 

別忘了把這個activity加入app/manifests/AndroidManifest.xml文件中

 

2.自定義一個Application,繼承ReactApplication ,編寫以下代碼:

 

 

 

記得在AndroidManifest.xml中引用

android:name=”.App”

 

3.在目錄res/layout中增加activity_main.xml文件,內容如下:

 

 

 

在MainActivity中通過按鈕啟動我們的ReactNativeActivity

 

 

4.app/src/main下新建assets文件夾

運行如下命令

react-native start

 

然後直接在android studio工程中,點擊上方工具欄的“run”按鈕,應該就可以了。
如果卡在了這一步:

沒關係,用資源管理器打開你工程的根目錄,在此目錄下重新運行一個命令行併在其中輸入如下命令

react-native bundle - -platform android - -dev false - -entry-file index.android.js - -bundle-output app/src/main/assets/index.android.bundle - -assets-dest app/src/main/res/

 

完成之後assets目錄下會生成以下兩個文件

確認一下react native service處於運行狀態,然後正常運行你的APP,點擊start,如果出現

恭喜你!你已經成功入坑,但是,實際項目中並不是這麼簡單!

 

 


 

項目實戰踩坑

 

1.技術棧

es6 + redux + react-redux + redux-thunk + react-navigation

 

2.項目心得

這個項目踩坑最多的地方還是在react-navigation的使用上:

 

1、同一頁面參數不同,多次回退始終進入同一個頁面:
比如詳情頁頁面a/cateId/xy,當傳入不同cateId參數“cd”跳轉到同一詳情頁a/cateId/cd的時候,頁面是正常改變的,但是回退的時候,第一次是回到a/cateId/cd,再次回退還是回到a/cateId/cd。不會觸發頁面render。
stackNavigator導航管理的頁面,在切換的時候,不是按照堆棧的push,pop形式,而是通過移動指針到對應的頁面,同時標記此頁面為激活狀態。

 

解決辦法是通過componentWillReceiveProps,shouldComponentUpdate以及componentDidUpdate,當nextProps中的params.cateId和當前的params.cateId不同的時候,觸發頁面的render。

 

2、實現手勢swipe向右滑動後退功能:
官方文檔介紹,react-navigation在根組件的navigationOptions設置中添加gesturesEnabled: true,就可以實現滑動切換切換頁面的需求,但是在真機上測試不生效。
通過讀源碼瞭解到,react-navigation內部是通過引入RN的PanResponder手勢識別系統來實現滑動的機制,只有在onMoveShouldSetPanResponder返回true的時候,才能執行接下來的手勢動作。具體執行方法如下:

 

 

因為上述代碼中的 GESTURE_RESPONSE_DISTANCE_HORIZONTAL 過小,導致始終return false,把這個值從20改到60就可以了。

 

3、實現頁面跳轉動畫效果

StackNavigator(RouteConfigs, StackNavigatorConfig);

 

在第二個參數StackNavigatorConfig的配置中,可以傳入mode: ‘card’,這個參數會在native端獲取預設的滑動效果,iOS端預設的是左右切換的效果,但是android端預設的是上下切換效果。為了實現統一的過場效果。
幸好react-navigation提供了一個transitionConfig介面,可以實現定製化滑屏效果。不知道該如何定製麽?沒有關係,源碼中已經在iOS端幫我們實現,稍微修改一下代碼就可以了。

 

 

FlatList問題:

1.ListHeaderComponent,ListFooterComponent
當FlatList有併列的組件的時候,會出現,其他併列的組件位置是固定的(類似於css中的position fixed),頁面只有FlatList區域是可以滾動的,為了實現這個頁面整體是可以滾動的,需要把FlatList上面的組件加入FlatList的ListHeaderComponent屬性中,同時把其下麵的組件加入到ListFooterComponent中。

2.通過利用getItemLayout,把高度提前設定好,可以較少一次RN計算高度的render。

 

圖片問題:

1.RN中的圖片有兩種來源:native內部圖片,cdn的圖片。
native內部圖片,直接可以通過require圖片名字取到,一定不要加.png等尾碼。
例如:

 

 

當然我們可以通過在打包的時候把通過相對路徑引入的內部圖片,

例如:

 

 

通過配置–asset-dest打包進入native原生目錄res中,這時候要註意,打出來的RN的bundle,只有放入android的assets文件夾下才能根據相對路徑取到這些存放在res目錄中的圖片。

cdn的圖片,只有指定圖片的寬高才能夠顯示出來。

與native交互的處理

  1. NativeModules:native暴露出來的模塊,可以通過NativeModules對象取到。

  2. 有些場景需要native直接傳遞某些參數到RN端,iOS可以通過調用initWithBundleURL,在initialProperties參數傳參,android通過getLaunchOptions把參數寫入返回的bundle中。在RN工程的根文件(例如app.js),通過this.props.key(key是屬性名字)直接取到。

 

 如果你喜歡我們的文章,關註我們的公眾號和我們互動吧。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 七.ECMAScript5關於數組的新方法1.forEach():遍曆數組,併為每個元素調用傳入的函數; 舉例: 1 var a = [1,2,3]; 2 var sum = 0; 3 //傳一個參數 4 a.forEach(function(v){ 5 sum += v; 6 }); 7 cons... ...
  • Div+CSS(嵌套+盒模型)佈局頁面完整實例流程: <!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>中國石油大學</title> </head> <style> *{ margin: 0px auto; padding: 0px ...
  • Js Window - 獲取瀏覽器視窗 全局變數是window對象的屬性 全局函數是window對象的方法 HTML DOM的document是window對象屬性之一 window.document.getElementById("header"); document.getElementById ...
  • 例子1: <input type="text" value="0" onkeyup="cleartwoNum(this)"> //限制input框輸入只能數字:function cleartwoNum(obj) { obj.value = obj.value.replace(/[^\d]/g, '' ...
  • 1.引入相應的js和css,我用到的時候是在jquery-ui的js裡面整合的,ui的css 2.先在html上寫一個input <input id="tags" class="form-control ui-autocomplete-input" autocomplete="off" type=" ...
  • 我們在前面的學習過程中不管是在學習angular還是vue1,都會遇到二級路由,我們現在先來看一下vue2中的一級路由。 首先要引入的是vue2與路由文件。 js代碼: html代碼: 看到這裡你們會不會感到不管是vue1還是vue2的路由都要比angular複雜一點,但是要比angular路由容易 ...
  • 1.第一步把表單,裡面需要回車的input,或者是其他的表單按鈕給一個clsss,例如下麵的$('.cls'); 2.第二步, 把下麵的代碼複製過去,填寫完最後一個自動提交:$("#savedown").click(); 3.選中input的框的時候一定要全部選中,不然操作會不方便,給一個提示 $( ...
  • history.pushState 和 history.replaceState 可以在不刷新當前頁面的情況下更改URL,但是這樣就無法獲取通過AJAX得到的新頁面的內容了。雖然各種HTML5文檔說 window.onpopstate 事件可以攔截 pushState 的消息,但在實際的測試中, o ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...