Native、Web App、Hybrid、React Native(後面以RN簡稱)、Weex 間的異同點,後期同步 小程序 和 PWA前端
此處App爲應用,application,並不是咱們一般講的手機App
經常使用的幾種APP開發模式-腦圖web
傳統的原生App開發模式,有iOS和aOS兩大系統,須要各自語言開發各自App。小程序
優勢:性能和體驗都是最好的
缺點:開發和發佈成本高
舉個栗子:網易管家App (Tab1,Tab2)
應用技術:Swift,OC,Javasegmentfault
移動端的網站,常被稱爲H5應用,說白了就是特定運行在移動端瀏覽器上的網站應用。通常泛指 SPA(Single Page Application)模式開發出的網站,與MPA(Multi-page Application)對應。後端
優勢:開發和發佈成本最低
缺點:性能和體驗不能講是最差的,但也受到瀏覽器處理能力的限制,屢次下載一樣會佔用用戶必定的流量
舉個栗子:網易管家APP(Tab3)
應用技術:ReactJS,RegularJS,VueJS等等api
混合模式移動應用,介於Web App、Native App這二者之間的App開發技術,兼具「Native App良好交互體驗的優點」和「Web App跨平臺開發的優點」(百度百科解釋)瀏覽器
主要的原理是,由Native經過JSBridge等方法提供統一的API,而後用Html+Css實現界面,JS來寫邏輯,調用API,最終的頁面在Webview中顯示,這種模式下,Android、iOS的API通常有一致性,Hybrid App因此有跨平臺效果。網絡
優勢:開發和發佈都比較方便,效率介於Native App、Web App之間
缺點:學習範圍較廣,須要原生配合
舉個栗子:FanReact,我愛我家App,東方航空App,富國基金-富國錢包App
應用技術:PhoneGap,AppCan,Wex5,APICloud等app
Facebook發現Hybrid App存在不少缺陷和不足,因而發起開源的一套新的App開發方案RN。使用JSX語言寫原生界面,js經過JSBridge調用原生API渲染UI交互通訊。工具
優勢:效率體驗接近Native App,發佈和開發成本低於Native App
缺點:學習有必定成本,且文檔較少,免不了踩坑
舉個栗子:Facebook、Youtube、Discord、QQ、百度等等
阿里巴巴開發團隊在RN的成功案例上,從新設計出的一套開發模式,站在了巨人肩膀上並有淘寶團隊項目作養料,廣受關注,2016年4月正式開源,並在v2.0版本官方支持Vue.js,與RN平起平坐。
優勢:單頁開發模式效率極高,熱更新發包體積小,而且跨平臺性更強
缺點:剛剛起步,文檔欠缺;社區沒有RN活躍,功能尚不健全,暫不適合徹底使用Weex開發App
舉個栗子:淘寶、天貓、阿里雲、優酷、閒魚、餓了麼等
Native App是一種基於智能手機本地操做系統如iOS、Android、WP並使用原生程式編寫運行的第三方應用程序,也叫本地app。通常使用的開發語言爲Java、C++、Objective-C。
自iOS和Android這兩個的手機操做系統發佈以來,在互聯網界今後就多了一個新的名詞:App意爲運行在智能的移動終端設備第三方應用程序)。
Native App由於位於平臺層上方,向下訪問和兼容的能力會比較好一些,能夠支持在線或離線,消息推送或本地資源訪問,攝像撥號功能的調取。可是因爲設備碎片化,App的開發成本要高不少,維持多個版本的更新升級比較麻煩,用戶的安裝門檻也比較高。可是比較樂觀的是,AppStore培養了一種比較好的用戶付費模式,因此在Apple的生態圈裏,開發者的盈利模式是一種明朗狀態,其餘market也在往這條路上靠攏。
一、相比於其它模式,提供最佳的用戶體驗,最優質的用戶界面,最華麗的交互
二、針對不一樣平臺提供不一樣體驗
三、可節省帶寬成本,打開速度更快
四、功能最爲強大,特別是在與系統交互中,幾乎全部功能都能實現
一、門檻高,原生開發人才稀缺,至少比前端和後端少,開發環境昂貴
二、沒法跨平臺,開發的成本比較大,各個系統獨立開發
三、發佈成本高,須要經過store或market的審覈,致使更新緩慢
四、維持多個版本、多個系統的成本比較高,並且必須作兼容
五、應用市場逐漸飽和,怎麼樣搶佔用戶時間須要投入大量時間和金錢,這也致使「殭屍」App的增多
說到Web App 很多人會聯想到 WAP,或者有人認爲,WAP就是WebApp,其實否則。
WebApp 與 WAP 最直接的區別就是功能層面。WAP更側重使用網頁技術在移動端作展現,包括文字、媒體文件等。而Web App更側重「功能」,是使用網頁技術實現的App。總的來講,Web App就是運行於網絡和標準瀏覽器上,基於網頁技術開發實現特定功能的應用。
響應式的大部分技術都是爲實現WebApp能適配多類客戶端而設計的。
Web網站通常分兩種,MPA(Multi-page Application)和SPA(Single-page Application)。而WebApp通常泛指SPA形式開發出的網站。這樣更像是一個App。
一、能夠跨平臺,調試方便
二、無需安裝,不會佔用手機內存,並且更新速度最快
三、不存在多版本問題,維護成本低
四、臨時入口,能夠隨意嵌入
一、依賴於網絡,第一次訪問頁面速度慢,耗費流量
二、受限於手機和瀏覽器性能,用戶體驗相較於其餘模式最差
三、功能受限,大量移動端功能沒法實現
四、入口強依賴於第三方瀏覽器,且只能以URL地址的形式存在,致使用戶留存率低(優勢即缺點)
混合開發,也就是半原生半Web的開發模式,由原生提供統一的API給JS調用,實際的主要邏輯有Html和JS來完成,最終是放在webview中顯示的,因此只須要寫一套代碼便可達到跨平臺效果,另外也能夠直接在瀏覽器中調試,很方便。最重要的是隻須要一個前端人員稍微學習下JS api的調用便可。
Hybird App 的較早實踐者是PhoneGap,隨後遍地開花,如Titanium、Salama、WeX五、Kerkee和國內的AppCan,項目各有各的實現方式,大體的原理基本相同。有幸在AppCan上海總部參與過一段時間的學習研究,以下大體簡介:
AppCan是基於HTML5技術的Hybird跨平臺移動應用開發工具。開發者利用Html5+Css3+JavaScript技術,經過AppCan IDE集成開發系統、雲端打包器等,快速開發出Android、iOS、WP平臺上的移動應用。
AppCan的平臺構成
在實際的APP開發中,AppCan能夠完成大部分的工做量,如圖示:
AppCan將App底層複雜的原生功能封裝在引擎、插件中,開發者僅需調用接口、打包編譯,就能夠得到原生功能;靈活的插件擴展機制。
開發者能夠像開發WebApp同樣開發app的視覺UI,以及絕大部分的交互,當須要使用原生功能(如攝像頭,陀螺儀等功能)時,只須要調用官方的API就能夠輕鬆實現Native的效果。至於JS和Native的通訊,經常使用的有URL監聽和絕大部分Hybrid廠商使用的JSBridge通訊,二者原理相近。
關於JsBridge的原理詳解,可見http://blog.csdn.net/xiangzhihong8/article/details/66970600
在Hybird概念盛行的時候,國內外各大公司也參與了探索,國外表明有Facebook、google、亞馬遜,國內的有騰訊、阿里巴巴、網易等,慢慢的他們發現Hybird嚴重受限於WebView的解析渲染效率,因而Facebook開始了他的類原生的研究探索。