React Native在Android當中實踐(一)——背景介紹
React Native在Android當中實踐(二)——搭建開發環境
React Native在Android當中實踐(三)——整合到Android專案當中
React Native在Android當中實踐(四)——程式碼整合
React Native在Android當中實踐(五)——常見問題
常見問題
若出現libgnustl_shared.so" is 32-bit instead of 64-bit類似錯誤
data:image/s3,"s3://crabby-images/84fe6/84fe65f4fdcb35b838316cbb50dc2e159cc0d2e4" alt="React Native在Android當中實踐(五)——常見問題"
android {
defaultConfig {
ndk {
abiFilters "armeabi-v7a", "x86"
}
packagingOptions {
exclude "lib/arm64-v8a/librealm-jni.so"
}
}
}
複製程式碼
若出現react-native run-android Android project not found
data:image/s3,"s3://crabby-images/e8660/e8660147e6e0aea7bbd5501068d9116110fdd779" alt="React Native在Android當中實踐(五)——常見問題"
若出現Could not get BatchedBridge, make sure your bundle is packaged correctly
data:image/s3,"s3://crabby-images/52cf3/52cf3d3e7745dad966958405821c681018d41005" alt="React Native在Android當中實踐(五)——常見問題"
若出現Could not connect to development server
data:image/s3,"s3://crabby-images/a6f96/a6f9690159c10e4dc9c8232e5a6ed6936e335f72" alt="React Native在Android當中實踐(五)——常見問題"
data:image/s3,"s3://crabby-images/8dbab/8dbabc693297f03acbb6efc3c1792a99e9f52a71" alt="React Native在Android當中實踐(五)——常見問題"
data:image/s3,"s3://crabby-images/a8016/a80167c406f7863453f1bb5f6aaafd0ad177a10a" alt="React Native在Android當中實踐(五)——常見問題"
data:image/s3,"s3://crabby-images/54532/545325e14f9633d90959b745b29f4a72a68ef294" alt="React Native在Android當中實踐(五)——常見問題"
3、飛航模式關閉
4、在cmd中輸入 adb reverse tcp:8081 tcp:8081,結果如下:
data:image/s3,"s3://crabby-images/d894f/d894f40baf9f84334e004b68a43368e91f185d65" alt="React Native在Android當中實踐(五)——常見問題"
data:image/s3,"s3://crabby-images/30a54/30a549a3c31bb2f7fdd7770c101da7bc24eee3f2" alt="React Native在Android當中實踐(五)——常見問題"
Make sure your bundle is packaged correctly or your're running a packager server
data:image/s3,"s3://crabby-images/56fab/56fabfabf0b5ed7be5504fe63a3bef44b047eb17" alt="React Native在Android當中實踐(五)——常見問題"
index.android.bundle是用來呼叫原生控制元件的js指令碼,每次當改變了 index.android.js,都需要使用上面的程式碼片段,來及時的更新index.android.bundle,然後打包才可以把新的index.android.js應用上,所以當沒有index.android.bundle檔案時,React-Native 專案是無法執行的。
解決辦法是
第一步:在Android/app/src/main目錄下建立一個空的assets資料夾(若已經存在請忽略) 出現這個問題是由於
index.android.bundle是用來呼叫原生控制元件的js指令碼,每次當改變了 index.android.js,都需要使用上面的程式碼片段,來及時的更新index.android.bundle,然後打包才可以把新的index.android.js應用上,所以當沒有index.android.bundle檔案時,React-Native 專案是無法執行的。
解決辦法是
第一步:在Android/app/src/main目錄下建立一個空的assets資料夾(若已經存在請忽略)
第二步:在Android Studio的Terminal進入專案根目錄執行下面程式碼:
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/
執行完畢後可以看到如下表示已經成功了
data:image/s3,"s3://crabby-images/572e1/572e18305975155aff6eea299a07afd3e795a305" alt="React Native在Android當中實踐(五)——常見問題"
data:image/s3,"s3://crabby-images/04751/04751b84220db87ee4d45eca3f6b708a08b78a05" alt="React Native在Android當中實踐(五)——常見問題"
data:image/s3,"s3://crabby-images/b36be/b36bea7b0fd76f23fc0507ee13652222ec5cb963" alt="React Native在Android當中實踐(五)——常見問題"
data:image/s3,"s3://crabby-images/6385a/6385aecec2dada81e509fb05a82783961a0ce7ac" alt="React Native在Android當中實踐(五)——常見問題"
data:image/s3,"s3://crabby-images/dc8c9/dc8c9f02afed98b089c90c91c0a771b7ded6661e" alt="React Native在Android當中實踐(五)——常見問題"
data:image/s3,"s3://crabby-images/1306b/1306baebcc312d240559a9c5118b794bc977298b" alt="React Native在Android當中實踐(五)——常見問題"
data:image/s3,"s3://crabby-images/a877f/a877f2f62d0d7a24a34114b33984e1ecd4efaa1c" alt="React Native在Android當中實踐(五)——常見問題"
data:image/s3,"s3://crabby-images/fdf46/fdf46db2753b6b6c1f249be07c63e60ef67a347b" alt="React Native在Android當中實踐(五)——常見問題"
data:image/s3,"s3://crabby-images/9e28a/9e28aa9905a93bf24c9f731188b2e8dedde5eb53" alt="React Native在Android當中實踐(五)——常見問題"
React Native的開發者模式
data:image/s3,"s3://crabby-images/b6e94/b6e9410e24f3e46fe571e31eb5152a3dfb2ca101" alt="React Native在Android當中實踐(五)——常見問題"
data:image/s3,"s3://crabby-images/5945f/5945ffdd506cd997e726221cea6f07c4e00ab19d" alt="React Native在Android當中實踐(五)——常見問題"
寫在最後
從我個人用 React Native 開發 APP 的體驗來看,React Native 適合 C/S 結構、業務型的 APP 或其中的模組,對於偏重底層技術的比如工具類 APP (或者模組),我還沒有使用 RN 嘗試過,不過想必顯然是不太適合的。總的來說,一個對於底層技術依賴不多,業務型,尤其是業務變動頻繁的應用或模組適合 RN 開發,而且一次開發,基本可以完全重用於兩個平臺,重要的是可以熱更新來應對業務邏輯更新頻繁、更新要求快、迅速修復線上 bug 等需求場景,目前看,RN 的熱更新並沒有被 Apple 封殺。 1. 無需編譯,我在第一次編譯了ipa裝好以後,就再也沒更新過app,只要更新雲端的js程式碼,reload一下,整個介面就全變了。 2. 多數佈局程式碼都是JSX,所有Native元件都是標籤化的,這對於前端程式設計師來說,降低了不少學習成本,也大大減少了程式碼量。不信你可以看看JSX編譯後的程式碼。 3. 複用React系統,也減少了一定學習和開發成本,更重要的是利用了React裡面的分層和diff機制。js層傳給Native層的是一個diff後的json,然後由Native將這個資料對映成真正的佈局檢視。 4. css-layout也是點睛之筆,前端可以繼續用熟悉的類css方式來編寫佈局,通過這個工具轉換成constrain佈局。 5. 系統只有js-objc的單向呼叫,就是把原生UI元件的方法通過javascritcore或者webview(低版本iOS)對映到js中來,整個呼叫過程是非同步的,這樣的設計令React native可以讓js執行在桌面chrome中,通過websocket連線Native code和桌面chrome,極大地方便了除錯。對其中的機制Bang的一篇文章寫得很詳細,我就不拾人牙慧了:React Native通訊機制詳解 « bang’s blog 。但這樣設計也會帶來一些問題,後面說。 6. 點按操作也被抽象成了一組元件(TouchableXXX),這種抽象方式是我在之前做類似工作中沒有想到的。facebook還列出Native為什麼和web「手感」不同的原因:實時的點按反饋和取消能力。React Native 這套相應機制設計得很完善,能像Native code那樣控制整個點按操作的所有過程。 7. Debug相當方便!修改了js以後,通過內建的nodejs watcher編譯成bundle,在模擬器裡面按cmd+r就可以看到效果。而且按cmd+d,可以開啟一個chrome視窗,所有的js都移到了chrome裡面執行,所以什麼斷點單步打呼叫棧,都不在話下。
上面的既是特點也是優點,下面說說缺點,或者應該說:「仍然遺留的問題」,在我看來,這個方案已經超越了Hybird方案。 1. 系統仍然(不得不)依賴原生元件暴露出來的元件和方法。舉兩個例子,ScrollView這個元件,在Native層是有大量事件的,scrollViewWillBeginDragging, scrollViewWillEndDragging,scrollViewDidEndDragging等等,這些事件在現有的版本都沒有暴露,基本上做不了元件聯動效果。另外,這個版本中有大量元件是iOS only的:ActivityIndicatorIOS、DatePickerIOS、NavigatorIOS、PickerIOS、SliderIOS、SwitchIOS、TabBarIOS、AlertIOS、AppStateIOS、LinkingIOS、PushNotificationIOS、StatusBarIOS、VibrationIOS,反過來看,剩餘的都是一些抽象程度極強的基本元件。這樣,使用者必須在不同的平臺下寫兩套程式碼,而且所有能力仍然強烈依賴 React native 開發人員暴露的介面。 2. 由於最外層是React,初次學習成本高,不像往常的Hybird方案,只要多學幾個JS API就可以開始幹活了。當然,React的確讓後續開發變得簡單了一些,這麼一套外來的(基於iOS)、殘缺不全的(css-layout)在React的包裝下,的確顯得不那麼面目可憎了。 另外,React Native仍然很不完善。文件還不全,我基本上是看著他的示例程式碼完成的demo,整合到已有app的文件也是今天才出來。按照官方的說法,Android版本要到半年後才釋出:Blog | React ,屆時整個系統設計可能還會有很大的變化。 ######參考 www.zhihu.com/question/27… github.com/reactnative… www.lcode.org/category/re…