成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

React-native-web跨平臺實戰

開發 架構
react-native-web走進了我們的視線,簡單介紹下rn-web,facebook公司維護的開源項目,一個能使 react-native組件能運行到web的庫。

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上門試駕發布。

作者簡介

 賈錫瑞 

二手車事業部-技術部。

 加入汽車之家多年,一直從事研發工作,現負責二手車之家以及其他汽車之家二手車業務的相關研發工作。

責任編輯:武曉燕 來源: 之家技術
相關推薦

2023-02-09 07:15:52

開發FlutterReact

2016-06-06 17:26:22

平臺開發

2025-02-18 10:30:59

2023-09-04 08:32:43

web開發圖像

2016-10-13 19:01:59

React NativUbuntu

2025-01-22 10:27:53

開發框架

2024-02-27 18:59:55

ReactRSDWeb

2016-07-29 13:47:05

RethinkDBWeb

2015-09-22 09:50:36

FacebookAndroid

2017-09-11 14:35:34

編輯器開發環境React

2016-08-12 08:49:46

React NativFacebookNative

2016-08-12 13:55:06

2023-06-24 17:09:06

React前端

2024-07-08 00:00:07

2015-02-01 09:26:10

2017-01-04 10:18:00

React NativScrollViewAndroid

2017-01-11 18:44:43

React Nativ觸摸事件Android

2016-08-15 13:34:37

React NativiOSjs入口

2017-03-09 13:29:04

ReactNative JSPatch

2017-03-21 21:37:06

組件UI測試架構
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产高清久久久 | 久久久久久久久99 | a级黄色毛片免费播放视频 国产精品视频在线观看 | 欧美精品影院 | 国产一区二区av | 成人h电影在线观看 | 中文字幕亚洲欧美日韩在线不卡 | 亚洲精品4| 国产精品久久久精品 | 国产综合久久 | 91视频在线观看 | 999精品视频 | 亚洲人久久 | 亚洲国产aⅴ精品一区二区 免费观看av | 黑人久久久 | 欧洲毛片 | 国产美女视频黄 | 午夜精品一区二区三区在线 | 最近日韩中文字幕 | www.成人在线视频 | 亚洲视频一区二区三区四区 | 欧美一级片 | 成人一区二区视频 | 午夜一区二区三区在线观看 | 久久久91 | 538在线精品 | 成人在线视频免费播放 | 亚洲成人一区 | 欧美日韩黄 | av黄色免费 | 久久久69 | 婷婷久久综合 | 一区二区三区免费 | 波多野吉衣久久 | 午夜精品久久久久久久久久久久 | 欧美国产激情 | 产真a观专区 | 国产精品自产拍 | 美女久久 | 国产精品jizz在线观看老狼 | 国产视频1区2区 |