理清 Native 和 Web 的亮點和痛點,借鑑對方亮點解決自身的痛點,並給出淘系 App 在這些方面的實踐。css
Mobile Web 的協做能力底層來自 Webkit,上層有 html/js/css 控制頁面的結構/行爲/樣式,URI 鏈接不一樣的資源,這樣的機制能夠被 Native 借鑑,構建 Native 的分層架構。html
天貓移動端GMV42% 年末推達 70%react
Native 融合 Web 的能力 VS
Web 融合 Native 能力:web
native一般用在:首頁、搜索頁、詳情頁、交易頁等重要核心的頁面,保證DNS垮了用戶依然可使用native完成核心交易
web頁:頻道、活動、促銷等不是很重要或者頻繁變更的頁面react-native
主要就是業務複用
兩邊分層架構對比
挑戰:解耦
工具:耦合圖-->清晰直觀、發現問題、評估集成複雜性
//todo工具怎麼用?api
問題:首次請求資源-->白屏、用戶體驗差
解決:業內廣泛使用:打包靜態資源到端,而後push到客戶端xcode
利用瀏覽器自身的緩存機制,二次加載不用向服務器請求全部資源,速度明顯快了不少
//todo打包系統?發佈系統?有現成工具?瀏覽器
監控:緩存
crash緣由:安全
action:
問題: 各BU私有API
解決: 統一Hybrid方案
打包、xList//todo、性能監控、HybridAPI、Native基礎
slogan: write once,run anywhere!learn once,write anywhere!
Native有更好的手勢識別、動畫效果、原生控件、合適的線程模型儘管Web Worker//todo能夠解決一部分問題,但如圖像解碼、文本渲染仍沒法多線程渲染,影響了Web的流暢性
咱們須要native的人機交互+web的開發效率和發佈能力
猜你喜歡 Web vs Native vs RN:
規劃:
組件:
其餘問題:
本身的組件庫//todo
引入RN//todo成本未知,暫時不
我司暫時木有crash的問題