軟件開(kāi)發(fā)中原生開(kāi)發(fā)與H5開(kāi)發(fā)和混合開(kāi)發(fā)的區(qū)別
目前市場(chǎng)上主流的APP分為三種:原生APP、Web APP(即HTML5)和混合APP三種,相對(duì)應(yīng)的定 制開(kāi)發(fā)就是原生開(kāi)發(fā)、H5開(kāi)發(fā)和混合開(kāi)發(fā)。那么這三種開(kāi)發(fā)模式究竟有何不同呢?下面我們就分別從這三者各自的優(yōu)劣勢(shì)來(lái)區(qū)分比較吧!
一、原生開(kāi)發(fā)
原生開(kāi)發(fā)(Native App開(kāi)發(fā)),是在Android、IOS等移動(dòng)平臺(tái)上利用官方提供的開(kāi)發(fā)語(yǔ)言、開(kāi)發(fā)類(lèi)庫(kù)、開(kāi)發(fā)工具進(jìn)行App開(kāi)發(fā)。比如Android是利用Java、Eclipse、Android studio;IOS是利用Objective-C 和Xcode進(jìn)行開(kāi)發(fā)。
通俗點(diǎn)來(lái)講,原生開(kāi)發(fā)就像蓋房子一樣,先打地基然后澆地梁、房屋結(jié)構(gòu)、一磚一瓦、鋼筋水泥、電路走向等,都是經(jīng)過(guò)精心的設(shè)計(jì)。原生APP也一樣:通過(guò)代碼從每個(gè)頁(yè)面、每個(gè)功能、每個(gè)效果、每個(gè)邏輯、每個(gè)步驟全部用代碼寫(xiě)出來(lái),一層層,一段段全用代碼寫(xiě)出來(lái)。
優(yōu)點(diǎn):
1、可訪問(wèn)手機(jī)所有功能(如GPS、攝像頭等)、可實(shí)現(xiàn)功能齊全;
2、運(yùn)行速度快、性能高,佳的用戶(hù)體驗(yàn);
3、支持大量圖形和動(dòng)畫(huà),不卡頓,反應(yīng)快;
4、兼容性高,每個(gè)代碼都經(jīng)過(guò)程序員精心設(shè)計(jì),一般不會(huì)出現(xiàn)閃退的情況,還能防止病毒和漏洞的出現(xiàn);
5、比較快捷地使用設(shè)備端提供的接口,處理速度上有優(yōu)勢(shì)。
缺點(diǎn):
1、開(kāi)發(fā)時(shí)間長(zhǎng),快則3個(gè)月左右完成,慢則五個(gè)月左右;
2、制作費(fèi)用高昂,成本較高;
3、可移植性比較差,一款原生的App,Android和IOS都要各自開(kāi)發(fā),同樣的邏輯、界面要寫(xiě)兩套;
4、內(nèi)容限制(App Store限制);
5、必須等下載完畢用戶(hù)才可以打開(kāi),獲得新版本時(shí)需重新下載應(yīng)用更新。
二、Web APP (HTML5)開(kāi)發(fā)
HTML5應(yīng)用開(kāi)發(fā),是利用Web技術(shù)進(jìn)行的App開(kāi)發(fā),可以在手機(jī)端瀏覽器里面打開(kāi)的網(wǎng)站就稱(chēng)之為webapp。Web技術(shù)本身需要瀏覽器的支持才能進(jìn)行展示和用戶(hù)交互,因此主要用到的技術(shù)是HTML、CSS、Javab以及jQuery、Vue、React等JS框架。
優(yōu)點(diǎn):
1、支持設(shè)備范圍廣,可以跨平臺(tái),編寫(xiě)的代碼可以同時(shí)在Android、IOS、Windows上運(yùn)行;
2、開(kāi)發(fā)成本低、周期短;
3、無(wú)內(nèi)容限制;
4、適合展示有大段文字(如新聞、攻略等),且格式比較豐富(如加粗,字體多樣)的頁(yè)面;
5、用戶(hù)可以直接使用新版本(自動(dòng)更新,不需用戶(hù)手動(dòng)更新)。
缺點(diǎn):
1、由于Web技術(shù)本身的限制,H5移動(dòng)應(yīng)用不能直接訪問(wèn)設(shè)備硬件和離線存儲(chǔ),所以在體驗(yàn)和性能上有很大的局限性;
2、對(duì)聯(lián)網(wǎng)要求高,離線不能做任何操作;
3、功能有限;
4、APP反應(yīng)速度慢,頁(yè)面切換流暢性較差;
5、圖片和動(dòng)畫(huà)支持性不高;
6、用戶(hù)體驗(yàn)感較差;
7、無(wú)法調(diào)用手機(jī)硬件(攝像頭、麥克風(fēng)等)。
三、混合(原生+H5)開(kāi)發(fā)
混合開(kāi)發(fā)(Hybrid App開(kāi)發(fā)),是指在開(kāi)發(fā)一款App產(chǎn)品的時(shí)候,為了提高效率、節(jié)省成本而利用原生與H5的開(kāi)發(fā)技術(shù)的混合應(yīng)用。通俗點(diǎn)來(lái)說(shuō),這就是網(wǎng)頁(yè)的模式,通常由“HTML5云網(wǎng)站+APP應(yīng)用客戶(hù)端”兩部份構(gòu)成。
混合開(kāi)發(fā)是一種取長(zhǎng)補(bǔ)短的開(kāi)發(fā)模式,原生代碼部分利用WebView插件或者其它框架為H5提供容器,程序主要的業(yè)務(wù)實(shí)現(xiàn)、界面展示都是利用與H5相關(guān)的Web技術(shù)進(jìn)行實(shí)現(xiàn)的。比如京東、淘寶、今日頭條等APP都是利用混合開(kāi)發(fā)模式而成的。
優(yōu)點(diǎn):
1、開(kāi)發(fā)效率高,節(jié)約時(shí)間。同一套代碼Android和IOS基本上都可使用;
2、更新和部署比較方便,每次升級(jí)版本只需要在服務(wù)器端升級(jí)即可,不再需要上傳到App Store進(jìn)行審核;
3、代碼維護(hù)方便、版本更新快,節(jié)省產(chǎn)品成本;
4、比web版實(shí)現(xiàn)功能多;
5、可離線運(yùn)行。
缺點(diǎn):
1、功能/界面無(wú)法自定:所有內(nèi)容都是固定的,不能換界面或增加功能;
2、加載緩慢/網(wǎng)絡(luò)要求高:混合APP數(shù)據(jù)需要全部從服務(wù)器調(diào)取,每個(gè)頁(yè)面都需要重新下載,因此打開(kāi)速度慢,網(wǎng)絡(luò)占用高,緩沖時(shí)間長(zhǎng),容易讓用戶(hù)反感;
3、安全性比較低:代碼都是以前的老代碼,不能很好地兼容新手機(jī)系統(tǒng),且安全性較低,網(wǎng)絡(luò)發(fā)展這么快,病毒這么多,如果不實(shí)時(shí)更新,定期檢查,容易產(chǎn)生漏洞,造成直接經(jīng)濟(jì)損失;
4、既懂原生開(kāi)發(fā)又懂H5開(kāi)發(fā)的高端人才難找。
目前混合開(kāi)發(fā)有兩種開(kāi)發(fā)模式:
一、原生主導(dǎo)的開(kāi)發(fā)模式:需要安卓和IOS原生開(kāi)發(fā)人員,整個(gè)App既有原生開(kāi)發(fā)的頁(yè)面,也有H5頁(yè)面,在需要H5頁(yè)面時(shí)由原生開(kāi)發(fā)工程師實(shí)現(xiàn)內(nèi)嵌,筆者近正在開(kāi)發(fā)的項(xiàng)目就使用這種開(kāi)發(fā)模式。
二、H5主導(dǎo)的開(kāi)發(fā)模式:只需要H5開(kāi)發(fā)工程師,借助一些封裝好的工具實(shí)現(xiàn)應(yīng)用的打包與調(diào)用原生設(shè)備的功能,如HBuilder的云端打包功能。
如何辨別原生和H5:
以近正在開(kāi)發(fā)的混合APP項(xiàng)目首頁(yè)為例:
1、看斷網(wǎng)的情況
把手機(jī)的網(wǎng)絡(luò)斷掉。然后點(diǎn)開(kāi)頁(yè)面。然后可以正常顯示的東西就是原生寫(xiě)的。
顯示404或者錯(cuò)誤頁(yè)面的是html頁(yè)面。
2、看布局邊界
可以打開(kāi) 開(kāi)發(fā)者選項(xiàng)中的顯示布局邊界,頁(yè)面元素很多的情況下布局是一整塊的是h5的,布局密密麻麻的是原生控件。頁(yè)面有布局的是原生的否則為h5頁(yè)面。(僅針對(duì)安卓手機(jī)試用)
3、看復(fù)制文章的提示,需要你通過(guò)對(duì)比才能得出結(jié)果。
比如是文章資訊頁(yè)面可以長(zhǎng)按頁(yè)面試試,如果出現(xiàn)文字選擇、粘貼功能的是H5頁(yè)面,否則是native原生的頁(yè)面。有些原生APP開(kāi)放了復(fù)制粘貼功能或者關(guān)閉了。而H5的css屏蔽了復(fù)制選擇功能等等情況。需要通過(guò)對(duì)目標(biāo)測(cè)試APP進(jìn)行對(duì)比才可知。
4、看加載的方式
如果在打開(kāi)新頁(yè)面導(dǎo)航欄下面有一條加載的線的話(huà),這個(gè)頁(yè)面就是H5頁(yè)面,如果沒(méi)有就是原生的。 微信里面打開(kāi)我們的H5頁(yè)面常見(jiàn)的有個(gè)綠色的加載線條。
5、看app頂部 導(dǎo)航欄是否會(huì)有關(guān)閉的操作
如果APP頂部導(dǎo)航欄當(dāng)中出現(xiàn)了關(guān)閉按鈕或者有關(guān)閉的圖標(biāo),那么當(dāng)前的頁(yè)面肯定的H5,原生的不會(huì)出現(xiàn)(除非設(shè)計(jì)開(kāi)發(fā)者故意弄的)美團(tuán)的、大眾點(diǎn)評(píng)的APP、微信APP當(dāng)加載h5過(guò)多的時(shí)候,左上角會(huì)出現(xiàn)關(guān)閉二字。
6、判斷頁(yè)面 下拉刷新的時(shí)候(前提是要有下拉刷新的功能)
如果界面沒(méi)有明顯刷新現(xiàn)象的是原生的,如果有明顯刷新現(xiàn)象(比如閃一下)的是H5頁(yè)面(ios和android)。
比如淘寶的眾籌頁(yè)面。
7、下拉頁(yè)面的時(shí)候顯示網(wǎng)址提供方的一定是H5網(wǎng)頁(yè)。
8、關(guān)鍵詞:山東中揚(yáng)信息技術(shù)有限公司、中揚(yáng)科技、中揚(yáng)科技胡經(jīng)理、公眾號(hào)、APP開(kāi)發(fā)那些事兒、山東app開(kāi)發(fā)、山東app開(kāi)發(fā)公司、臨沂app開(kāi)發(fā)、臨沂app開(kāi)發(fā)公司、APP開(kāi)發(fā)定制、微信開(kāi)發(fā)定制、小程序開(kāi)發(fā)、網(wǎng)站建設(shè)開(kāi)發(fā)、APP開(kāi)發(fā)中揚(yáng)胡經(jīng)理、app開(kāi)發(fā)中揚(yáng)科技、zhongyangapp
這就是區(qū)分軟件是原生開(kāi)發(fā)/混合開(kāi)發(fā)/H5開(kāi)發(fā)的區(qū)別,更多相關(guān)資訊可以移步我的主頁(yè)或私信給我。溦:zhongyangapp