隨著移動(dòng)設(shè)備越來(lái)越先進(jìn),對(duì)HTML5的支持度越來(lái)越高,我們進(jìn)軍移動(dòng)領(lǐng)域的時(shí)候,都會(huì)遇到一個(gè)問(wèn)題,是選擇HTML5和還是Native(用原生代碼編寫的本地程序)?HTML5的前景無(wú)疑是誘人的,一句“Write once, run anywhere”就可以秒殺一切。筆者最近兩年來(lái)對(duì)HTML5與Native有較為深入的研究,覺(jué)得兩者之間不能僅僅是二分法來(lái)選擇,還要根據(jù)企業(yè)自身的情況、團(tuán)隊(duì)的構(gòu)成、公司的戰(zhàn)略以及產(chǎn)品的特點(diǎn)來(lái)綜合選擇。
HTML5的發(fā)展前景我無(wú)疑是非??春玫模鞔蠊疽膊贿z余力的推動(dòng),目前主流的三大智能機(jī)操作系統(tǒng)iOS、Android和WIndows Phone都已經(jīng)支持大部分的HTML5特性。而移動(dòng)設(shè)備硬件軍備競(jìng)賽也為HTML5掃清硬件障礙。按照現(xiàn)在的發(fā)展速度,我判斷是在三年以內(nèi)甚至更快,移動(dòng)設(shè)備運(yùn)行HTML5將會(huì)完全沒(méi)有壓力,無(wú)論是標(biāo)準(zhǔn)還是硬件。現(xiàn)在主流的智能機(jī)已經(jīng)配置雙核處理器(之前筆誤為瀏覽器)和1G及以上的內(nèi)存,今年再出智能機(jī)沒(méi)這個(gè)配置你都不好意思發(fā)布了。
談?wù)凥TML5
1.HTML5可以讓你擺脫對(duì)平臺(tái)的依賴,用戶打開(kāi)瀏覽器,直接就可以訪問(wèn)你的應(yīng)用,而不需要經(jīng)過(guò)各種Store的審核。
2.實(shí)時(shí)更新,通常平臺(tái)的審核都需要七個(gè)工作日左右的時(shí)間,如果你發(fā)布之后發(fā)現(xiàn)問(wèn)題怎么辦?Web方式就不存在這種問(wèn)題。
3.Write once, run anywhere?
這是多少程序員的夢(mèng)想,也曾經(jīng)是Java讓人心動(dòng)的地方,但真正做過(guò)跨平臺(tái)解決方案的人都知道,這只是一句口號(hào)而已,跨平臺(tái)沒(méi)那么容易玩轉(zhuǎn)的。沒(méi)錯(cuò),HTML5可以實(shí)現(xiàn)Write once, run anywhere,但我們總不能寫一個(gè)Hello World來(lái)run anywhere吧。不同平臺(tái)有自己的特性,不同平臺(tái)用戶也有自己的操作習(xí)慣,如果你想討好所有人,也就意味著你無(wú)法討好任何人。
4.減少開(kāi)發(fā)工作量或者讓開(kāi)發(fā)變得更簡(jiǎn)單?
對(duì)老板來(lái)說(shuō),這是一個(gè)非常誘人話題,因?yàn)楣ぷ髁康臏p少就意味著節(jié)省更多的錢,沒(méi)有老板不喜歡用更少的錢辦更多的事。而且目前一個(gè)非常大的問(wèn)題是,移動(dòng)設(shè)備開(kāi)發(fā)人員特別是iOS開(kāi)發(fā)人員非常不好找,因?yàn)榧夹g(shù)好的都自己做應(yīng)用了,人家自己也能賺個(gè)月薪上萬(wàn)甚至更多,為什么要進(jìn)你的公司?怎么說(shuō)也是自己的事業(yè),擁有無(wú)限可能,還可以充分享受自由。但如果可以充分利用HTML5,那么我們就可以招聘Web前端的開(kāi)發(fā)人員來(lái)構(gòu)建移動(dòng)應(yīng)用,這樣就不愁招人的有問(wèn)題。因?yàn)樵谠S多人的眼里,HTML5/CSS/Javascript都是沒(méi)多大技術(shù)含量的東西,實(shí)在找不到人,找些實(shí)習(xí)生學(xué)學(xué)也就會(huì)了。
但問(wèn)題是,工作量真的會(huì)減少嗎?技術(shù)門檻真的那么低么?答案是NO!
我曾經(jīng)花了半年的時(shí)間去開(kāi)發(fā)一個(gè)基于HTML5的移動(dòng)框架,用來(lái)模擬Native應(yīng)用,讓HTML5應(yīng)用看起來(lái)盡可能看起來(lái)像本地應(yīng)用,注意:是像。這有點(diǎn)像jTouch,但不一樣的是,它能和Native程序很好地交互,并且能調(diào)用本地資源等等特性。但最后結(jié)果確不是那么令人滿意,比如HTML5在動(dòng)畫切換的時(shí)候,有時(shí)候候會(huì)有一些莫名其妙的問(wèn)題,當(dāng)然你可以告訴我把動(dòng)畫效果關(guān)了,但這看起來(lái)很死板,最后我不得不關(guān)閉某些動(dòng)畫。而用Objective-c編寫程序就沒(méi)這么多事了,幾句簡(jiǎn)單的代碼可以實(shí)現(xiàn)很酷的動(dòng)畫,用HTML5需要更多的代碼,甚至根本無(wú)法實(shí)現(xiàn)。
而且移動(dòng)設(shè)備上的HTML5開(kāi)發(fā)對(duì)開(kāi)發(fā)人員的技術(shù)有非常高的要求,不是一般的Web前端人員能解決的,通常擁有這樣技術(shù)的人才,工資水平也不會(huì)比Native開(kāi)發(fā)人員低多少。如果你僅僅是要開(kāi)發(fā)一個(gè)移動(dòng)設(shè)備上的網(wǎng)站,這會(huì)簡(jiǎn)單很多,但如果你希望模擬Native應(yīng)用,并且擁有較高的效率和優(yōu)雅的用戶體驗(yàn),這就很有技術(shù)含量了。不要小看Javascript這類Web開(kāi)發(fā)語(yǔ)言,通常我的看法是越簡(jiǎn)單的語(yǔ)言越會(huì)體現(xiàn)出技術(shù)人員的水平,特別是規(guī)劃設(shè)計(jì)能力。
5.其它問(wèn)題,資源調(diào)用的限制,比如說(shuō)在iOS中有Javascript運(yùn)行不能超過(guò)15秒的限制,不能調(diào)用本地硬件設(shè)備(如相機(jī)等),無(wú)法使用推送服務(wù)等。
如何選擇?
是否這樣,我們就不要選擇HTML5了呢?我在前面說(shuō)過(guò):“要根據(jù)企業(yè)自身的情況、團(tuán)隊(duì)的構(gòu)成、公司的戰(zhàn)略以及產(chǎn)品的特點(diǎn)來(lái)綜合選擇”,我最近在關(guān)于HTML5討論的微博上也有談到:“HTML5是戰(zhàn)略性方向,F(xiàn)acebook和Google已經(jīng)布局,Google Mobile在iPhone上的體驗(yàn)可以媲美Native。基本上Native+Web App可以秒殺多數(shù)應(yīng)用,如果不愿意受制于各種Store,單獨(dú)的Web App也是一個(gè)不錯(cuò)的方向。對(duì)于游戲類和對(duì)硬件環(huán)境依賴嚴(yán)重的應(yīng)用,只能是是Native”。僅管有這樣那樣的問(wèn)題,但HTML5是一種趨勢(shì),在未來(lái)三至五年,HTML5將會(huì)取代很多本地應(yīng)用,但就像多年前我們一直在談B/S架構(gòu)取代C/S架構(gòu)一樣,這需要一個(gè)過(guò)程。
通常在HTML與Native之間,我們有三種選擇——HTML5、Native App以及HTML5+Native,HTML5就是指純Web的移動(dòng)應(yīng)用,用戶需要打開(kāi)瀏覽器,然后輸入應(yīng)用的網(wǎng)址訪問(wèn)。Native指的是基于特定平臺(tái)開(kāi)發(fā)的應(yīng)用。Native+HTML5實(shí)際上是一種加殼的方式,將HTML5用和瀏覽器封裝起來(lái),但這對(duì)用戶是不可見(jiàn)的,用戶沒(méi)有任何異物感,和Store上下載的App沒(méi)有什么兩樣。
就我個(gè)人而言,我是比較推崇HTML5+Native的,這種加殼的方式,可以讓你享受Native與HTML5的雙重好處,但缺點(diǎn)是對(duì)技術(shù)含量要求較高。當(dāng)然我這里指的不是簡(jiǎn)單地把HTML5封裝到一個(gè)瀏覽器里面,Native與HTML5會(huì)有許多的交互,實(shí)際上這有點(diǎn)像混合硬盤,我們即便享受SSD的快速,但我們又想獲得機(jī)械硬盤的高性價(jià)比。我認(rèn)為在5-10年內(nèi),這都會(huì)是一種不錯(cuò)的解決方案,當(dāng)HTML5和硬件發(fā)展到一定水平之后,我們?cè)偻耆D(zhuǎn)向HTML5成本也會(huì)非常低的。
如何做?
假定現(xiàn)有一個(gè)對(duì)本地環(huán)境依賴不那么嚴(yán)重的項(xiàng)目,如微博客戶端,各種社交美食甚至LBS應(yīng)用,我們都可以采用HTML5+Native。如圖所示,我們可以將核心的代碼Core層用封裝起來(lái),這個(gè)代碼和平臺(tái)無(wú)關(guān),主要是業(yè)務(wù)邏輯以及和Shell的交互,代碼用Web語(yǔ)言編寫。在Core層上我們?cè)俑鶕?jù)不同的移動(dòng)平臺(tái)制作不同的UI。最后我們將上述兩層放到各平臺(tái)的Shell中,這個(gè)Shell主要是由瀏覽器來(lái)完成工作,當(dāng)然還包括一些硬件操作和讀取本地資源,如GPS、重力感應(yīng)、相機(jī)調(diào)用、地圖、推送通知或者IAP等。
移動(dòng)開(kāi)發(fā)中HTML5能否替代本地程序
我們可以把Web的升級(jí)部分部署到服務(wù)器上,用戶運(yùn)行App后,App會(huì)向服務(wù)器講求獲取最新的Web程序并下載運(yùn)行,這樣可以達(dá)到跳過(guò)各種Store的更新審核,達(dá)到快速更新的目的。而且假如用戶無(wú)法訪問(wèn)互聯(lián)網(wǎng),我們可以讓用戶使用上一個(gè)版本的程序,不會(huì)像純Web App那樣要求用戶一定要聯(lián)網(wǎng)
好處
1.用戶可以離線使用
2.更新下載量及少,可以全部更新,也可以選擇替換部分文件
3.代碼很安全安全,眾所周知Web應(yīng)用有一個(gè)很大的問(wèn)題就是代碼安全的問(wèn)題,但現(xiàn)在我們可以將Web代碼全部加密,本地應(yīng)用解密后再運(yùn)行,大大的提供了代碼的安全性。
4.可以通過(guò)瀏覽器作為中介充分利用Native的好處,比如說(shuō)可以使用GPS、照相機(jī)、本地相冊(cè)、讀取本地聯(lián)系人,也可以使用推送功能等,最重要的是,某些Web無(wú)法實(shí)現(xiàn)的功能,我們可以利用Native來(lái)實(shí)現(xiàn)。
5.跨平臺(tái),多數(shù)核心代碼不用重寫,Javascript的代碼用得好的話,在許多地方都可以用到,包括移動(dòng)應(yīng)用、移動(dòng)網(wǎng)站、PC網(wǎng)站、各種瀏覽器插件,甚至可以用WebKit封裝作為跨平臺(tái)的應(yīng)用程序。誠(chéng)然,這種方式并非完全跨平臺(tái),但這樣也足以減少很多工作量了,特別是后期的維護(hù)。而且完全的跨平臺(tái)是沒(méi)有意義的,不同平臺(tái)有自己的風(fēng)格,為了更好的用戶體驗(yàn),界面層還是需要針對(duì)性開(kāi)發(fā)的。
壞處
我覺(jué)得最大的壞處是技術(shù)難度高,如果僅僅是簡(jiǎn)單的瀏覽器封裝幾個(gè)HTML文件,那沒(méi)什么技術(shù)難度,但如果要打造一個(gè)系統(tǒng)級(jí)的東西,這就很有技術(shù)難度了。這要求有人要了解三個(gè)主流平臺(tái)的瀏覽器特性,通曉Native程序的開(kāi)發(fā),要精通HTML5/CSS3/Javascript,最重要的是,要有較強(qiáng)的架構(gòu)設(shè)計(jì)能力。
如果要再找一個(gè)壞處的話,就是它不能滿足所有的需要,它并不能代替Native,但我認(rèn)為他可以替代大部的Native。
適合我們嗎?
首先從產(chǎn)品的角度考慮,你的產(chǎn)品是否嚴(yán)重依賴于本地環(huán)境,比如說(shuō)圖像處理和華麗的游戲之類的。第二要考慮的是你的技術(shù)團(tuán)隊(duì)的構(gòu)成,如果你們的團(tuán)隊(duì)有一個(gè)能解決這些問(wèn)題的牛人,并且有一些清通Web前端的人,那我覺(jué)得你可以考慮用這種方式。技術(shù)選型非常重要,稍有不慎,后患無(wú)窮。第三個(gè)要考慮你們公司的戰(zhàn)略,對(duì)HTML5未來(lái)發(fā)展的看法,愿意在移動(dòng)互聯(lián)網(wǎng)上付出多少代價(jià),是否愿意做前瞻性的事,是否愿意在前期投入較多的資源,是否允許試錯(cuò)等等。
更多信息請(qǐng)查看IT技術(shù)專欄