隨著對用戶體驗要求的提高,產品要求提升用戶體驗,多端體驗一致。隨著多端相同的業務也越來越多,需要投入IOS,Android,Web多端開發人員。這就迫切的需要一種一次開發同時使用在Android ,IOS ,Web的解決方案。達到降本增效的目的。在幾個小業面嘗試,總結經驗後,我們採用react-na... ...
1.背景
隨著對用戶體驗要求的提高,產品要求提升用戶體驗,多端體驗一致。隨著多端相同的業務也越來越多,需要投入IOS,Android,Web多端開發人員。這就迫切的需要一種一次開發同時使用在Android ,IOS ,Web的解決方案。達到降本增效的目的。在幾個小業面嘗試,總結經驗後,我們採用react-native-web多端適配。
2.問題
a.對用戶體驗要求越來越高,主推RN,flutter逐步替代原始H5。
b.現RN代碼獨立在汽車之家APP和二手車之家APP獨立運行,在H5環境運行還沒嘗試。
c.對RN接觸較多較熟悉,對VUE等開發Html語言瞭解不多。
d.RN原生依賴的處理,大部分頁面vue開發,如何掛載rn-web產物
3.解決方案
react-native-web走進了我們的視線,簡單介紹下rn-web,facebook公司維護的開源項目,一個能使 react-native組件能運行到web的庫。
4.說乾就乾
► a.搭建rn-web環境
npx react-native init rnweb064 --version 0.64.2
註:為什麼選這個版本,因為主軟體現在是0.64.2版本,cocoapods因為牆的問題可能會失敗,不會爬牆的多試幾次也能成功。
yarn add react-native-web
rn-web的核心,他主要解決了react代碼轉譯js代碼
yarn add -D babel-plugin-react-native-web webpack webpack-cli webpack-dev-server html-webpack-plugin react-dom babel-loader url-loader @svgr/webpack
h5開發多件套,做H5的你應該比我更熟悉。
直接拷貝 App.web.js、index.html、index.web.js、webpack.config.js
修改package.json增加編譯及打包
"build": "rm -rf dist/ && webpack --mode=production --config webpack.config.js",
"build1": "rm -rf dist/ && webpack --mode=development --config webpack.config.js",
"dev": "webpack-dev-server --config webpack.config.js --port 8090 --open",
修改後目錄結構:
增加src文件夾,rn-web環境搭建到這裡已完成,遇到各種環境報錯不再列舉,現已可以運行出demo ,大部分文章到這就結束了。
但我們需要解決的問題幾乎是沒有提到的
1.如何調試log輸出;
2.如何集成在其他Html內,併進行相互通信;
3.react-native集成了原生橋接如何分離;
4.多端業務代碼如何管理
接下來開始我們的src里編碼,並附上我們解決上述問題的方案
需要註意
1.在webpack.config.js引入src文件夾,讓rn-web可編譯
2.index.html只是我們一個殼,我們並不直接使用,所以可以增加背景調試工具VConsole等
► b.rn編碼這裡簡單的介紹一個輸入框在H5的樣式
二手車APP(ios,android);汽車之家(ios,android);
具體實現,如何做到多端共用一套業務代碼。
頁面構成分析
1.輸入框
2.listview
3.圖片
4.鍵盤處理
5.網路請求
6.通知選擇回調
7.返回按鈕
8.公共工具類(劉海屏判斷等)
上述大體分為三個部分
1.react-native預設支持(1,2,3,4)
這部分我們無需處理,rn-web預設支持。
2.主軟體獨立封裝(5,6,7)
我們採用同類名,同方法名,區分端,空實現,保證業務代碼在不同平臺使用不同實現
業務入口-分端處理index.web.js和index.js分別持有下列入口
H5的入口 app.web.js
APP的入口 app.js
► a.網路請求
H5 我們採用fetch實現
在APP端採用原生橋接的網路庫實現
► b.通知實現
APP端同理使用現有封裝實現AHRNEventDispatcher不多介紹
h5頁面我們採用了同類名,空實現,保證編譯正常。
現在我們能運行一套業務代碼在不同的環境了,其他UI差異如何處理。
1.業務判斷Platform.OS != 'web'
2.增加尾碼如上圖,讓reactnative可選擇編譯。
► c.關於回調及H5裝載
rn-web打包後就是個js文件,可直接放到現有任何js文件中。註意需要放
入口。
這個js只是我們h5的一個頁面,其他頁面採用vue開發,H5方法直接掛在window上,保證其他頁面能夠調用到。
ReactNative編碼如下:
if (Platform.OS == 'web') {
let json = JSON.stringify(mData);
window.che168_map_addressData_example.addOverlayFromAddress(json);
this.closeThisView();
} else {
this._closeNativeView(mData);
}
H5目錄結構
react目錄結構
共用業務代碼HomeW,不同業務封裝Util,主軟體的reactnative-lib封裝usedcar-web-lib
► d.關於業務代碼如何共同管理,我們採用git子模塊進行管理。
總結
本文這個業務比較簡單,但也夠說出關鍵思想,上述只有幾處依賴原生代碼,併進行了依賴改動
現有ReactNative已依賴大量原生橋接實現,這個修改是漫長的,但為了體驗這是值得的。
在後續業務中,我們將繼續同構業務到rn-web進行驗證。
上述功能已在H5拍品直供,APP上門試駕發佈。
作者|賈錫瑞
本文來自博客園,作者:古道輕風,轉載請註明原文鏈接:https://www.cnblogs.com/88223100/p/React-native-web-cross-platform-combat.html