自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

我為什么從PhoneGap中逃離

開發(fā) 前端
我是一名移動(dòng)應(yīng)用的開發(fā)者,從JAVA為主的Android到以O(shè)bjective-C為主的iOS最后到以HTML5為主的跨平臺(tái)開發(fā),我已經(jīng)走過了五年多的時(shí)光,而我也從一個(gè)底層的碼農(nóng)成長(zhǎng)為項(xiàng)目負(fù)責(zé)人。

每一位程序員都有自己的技術(shù)信仰,我也不例外。但當(dāng)技術(shù)信仰遇到實(shí)際工作中的問題時(shí),你又要怎么做呢?還記得剛剛接觸HTML5做跨平臺(tái)開發(fā)的時(shí)候這樣的問題就擺在了我面前。

當(dāng)初公司決定選擇PhoneGap作為核心框架,不過在之后的工作中就慢慢覺得PhoneGap并不像人們說的那么好,至少在我的項(xiàng)目中的表現(xiàn)不是那么***。

從項(xiàng)目研發(fā)到整體的UI體驗(yàn),隨之而來(lái)的各種問題都有待解決。你可以嘲笑我,也可以說我根本不懂,不過在應(yīng)用開發(fā)的過程中任何的問題都不可忽視。

項(xiàng)目研發(fā)

在項(xiàng)目研發(fā)中主要是開發(fā)環(huán)境與應(yīng)用實(shí)現(xiàn),不過PhoneGap在終端平臺(tái)的支持與應(yīng)用打包上也出現(xiàn)了些問題。

1.支持終端平臺(tái)

表面上來(lái)看,PhoneGap支持的平臺(tái)數(shù)量最多。但是在實(shí)際開發(fā)過程中,不管用什么平臺(tái)開發(fā),除去平臺(tái)封裝的擴(kuò)展對(duì)象,完全遵循W3C標(biāo)準(zhǔn),也不可能完全運(yùn)行在多個(gè)平臺(tái)上,所以說跨多個(gè)平臺(tái)是不現(xiàn)實(shí)的,還是需要針對(duì)不同的平臺(tái)進(jìn)行實(shí)現(xiàn)。

2.開發(fā)環(huán)境

在應(yīng)用開發(fā)的過程中,開發(fā)環(huán)境至關(guān)重要,但是PhoneGap沒有自己的IDE開發(fā)環(huán)境,官方推薦一些公開的第三方html編輯軟件(第三方編輯器不可能將PhoneGap所做的JS擴(kuò)展表現(xiàn)出來(lái))。

對(duì)開發(fā)者來(lái)講,用PhoneGap開發(fā)并不是單純的html + css + javascript的開發(fā),要進(jìn)行PhoneGap開發(fā),開發(fā)者必須要下載以上7個(gè)平臺(tái)廠商所提供的開發(fā)環(huán)境,IDE等(這個(gè)PhoneGap官網(wǎng)有描述),環(huán)境搭建完成后方可進(jìn)行模擬調(diào)試,對(duì)于沒有接觸過手機(jī)開發(fā)的web開發(fā)者而言,還需要學(xué)習(xí)很新的東西,入門門檻太高,開發(fā)難度無(wú)疑要加大。

3.打包部署

做過應(yīng)用開發(fā)的人都知道,基于開發(fā)環(huán)境必須針對(duì)不同的SDK進(jìn)行開發(fā),所以打包部部署步驟比較繁瑣,而且每個(gè)平臺(tái)要在不同的環(huán)境下操作。最近推出在線打包,但是需要付費(fèi)購(gòu)買使用的。

4.應(yīng)用的實(shí)現(xiàn)

當(dāng)進(jìn)行應(yīng)用實(shí)現(xiàn)的時(shí)候,使用PhoneGap開發(fā)應(yīng)用必須在網(wǎng)頁(yè)當(dāng)中引用一個(gè)JS包,才能使用本地?cái)U(kuò)展對(duì)象。過多過大(例如再引用JQ)的JS包引用將加重引擎的負(fù)擔(dān),從而影響應(yīng)用性能和用戶體驗(yàn),所有UI完全依靠html和css完成。

不僅如此,手機(jī)上的webkit存在IFrame不支持height屬性,css樣式不支持z-index,position,overflow等屬性的硬傷,也就是頁(yè)面的區(qū)域滾動(dòng)在正常網(wǎng)頁(yè)布局下是無(wú)法做到的,只能依賴JS或者native UI。不幸的是PhoneGap把這個(gè)問題留給了我們開發(fā)者,開發(fā)者只能選擇JS。在頁(yè)面滾動(dòng)上用JS效率是相當(dāng)?shù)偷?,尤其在android的中低端手機(jī)上表現(xiàn)更為明顯。

用戶體驗(yàn)

用戶體驗(yàn)是每一個(gè)應(yīng)用是否能夠立足生存,被用戶所接受并長(zhǎng)期使用的原因,所以導(dǎo)致PhoneGap在用戶體驗(yàn)上有一定的差距,這里我主要是對(duì)PhoneGap引擎問題的分析:

1. 平臺(tái)穩(wěn)定性差

從PhoneGap公布的源代碼和一些用PhoneGap開發(fā)出來(lái)的應(yīng)用體驗(yàn)上來(lái)看,PhoneGap是沒有經(jīng)過完整而系統(tǒng)的測(cè)試的,或者還沒有進(jìn)行過機(jī)型的適配,還存在很多的BUG,許多應(yīng)用有手機(jī)平臺(tái)版本的限制等等。

并且因?yàn)殚_源,不斷有開發(fā)者往上提交代碼,各平臺(tái)的兼容和同一平臺(tái)不同版本之間的兼容問題在PhoneGap開發(fā)上會(huì)越來(lái)越大。UI上最明顯的問題就是頁(yè)面被放大。Android平臺(tái)的webkit會(huì)根據(jù)手機(jī)設(shè)備屏幕的分辨率,密度,大小等條件來(lái)對(duì)網(wǎng)頁(yè)進(jìn)行0.75~ 1.5倍的縮放,以適應(yīng)屏幕。這意味著在不更改webkit縮放比例的情況下,若網(wǎng)頁(yè)當(dāng)中寫了類似width:10px; 時(shí),實(shí)際上可能變成了10 * 1.5。同時(shí),在帶有輸入框的頁(yè)面當(dāng)中,一旦選中輸入框,頁(yè)面立即會(huì)出現(xiàn)再被放大的效果,并且放大后無(wú)法縮回,導(dǎo)致用戶看到的UI效果跟開發(fā)者想要的想要的效果相差較大。

2. 對(duì)國(guó)內(nèi)廠商終端的適配差

PhoneGap現(xiàn)有功能上有多處存在不完善。比如定位功能,在關(guān)閉GPS,GPRS,WIFI、系統(tǒng)基于網(wǎng)絡(luò)定位設(shè)置的情況下(此時(shí)連接了WIFI),是無(wú)法獲取到地理位置的,國(guó)內(nèi)手機(jī)廠商的手機(jī)經(jīng)常崩潰或運(yùn)行錯(cuò)誤,所以用戶體驗(yàn)差。

3. 不支持多窗口與動(dòng)畫卡頓

在整體UI上,PhoneGap開發(fā)過程中自始至終只存在一個(gè)窗口,也就是所有的網(wǎng)頁(yè)都運(yùn)行在這個(gè)窗口當(dāng)中的,比如窗口的切換,過度等的動(dòng)畫效果,使用JS和CSS3可以實(shí)現(xiàn)一些動(dòng)畫效果,效率是很低的,并且只局限于當(dāng)前網(wǎng)頁(yè)內(nèi),至少在現(xiàn)階段部分設(shè)備硬件配備還沒跟上之前是這樣的,而且除IOS以外的終端設(shè)備,廠商繁多,參差不齊,更難確保做出來(lái)的應(yīng)用能夠良好的運(yùn)行在各個(gè)平臺(tái),所以用戶體驗(yàn)不好。

4. UI延遲效果差,易崩潰

從PhoneGap開源出來(lái)的代碼架構(gòu)來(lái)看,PhoneGap本身的機(jī)制會(huì)導(dǎo)致UI上有一定的延遲,在不改現(xiàn)有架構(gòu)的基礎(chǔ)上這個(gè)問題是不可避免的。比如傳感器的速度明顯過慢,照相機(jī)打開拍照后回調(diào)時(shí)間過長(zhǎng)等,這些都是在非常簡(jiǎn)單的網(wǎng)頁(yè)下的表現(xiàn)效果。由于PhoneGap本身基于開源策略架構(gòu)(利于開發(fā)者往上擴(kuò)充功能)和在JS層面做了大量工作的原因,PhoneGap開發(fā)無(wú)論在iPhone還是在Android上都并沒有走本身平臺(tái)所特有的JS擴(kuò)展方式,而是采取了線程休眠,暫停瀏覽器timer等方式來(lái)獲取回調(diào),直接導(dǎo)致延遲。另外,如照相機(jī)接口,PhoneGap返回給用戶的并不是類似于文件存儲(chǔ)地址的字符串,而是將相片轉(zhuǎn)為了二進(jìn)制發(fā)給用戶,導(dǎo)致這個(gè)操作非常耗資源,并且時(shí)間消耗很長(zhǎng),在圖片大的情況下,還有可能因?yàn)镺utOfMemorySize異常而引起應(yīng)用直接崩潰。

也許這些問題在你的團(tuán)隊(duì)中稱不上什么問題,但是在一個(gè)資源不是那么豐富的團(tuán)隊(duì)中這些問題就顯得尤為突出。而且,在應(yīng)用開發(fā)的過程中各種細(xì)節(jié)問題都不可忽略,追求***的應(yīng)用要從細(xì)節(jié)做起。雖然PhoneGap可以實(shí)現(xiàn)很多跨平臺(tái)應(yīng)用的開發(fā),但開發(fā)者尤其是項(xiàng)目統(tǒng)籌人員在選擇框架的時(shí)候一定要三思而后行。

 

責(zé)任編輯:彭凡 來(lái)源: 51CTO
相關(guān)推薦

2019-05-14 11:15:51

微軟員工上市公司

2010-03-09 13:16:11

LinuxWindows

2021-08-23 08:19:48

辭職Google工程師

2019-11-20 09:00:52

Linux 開發(fā)操作系統(tǒng)

2013-04-25 10:14:39

Facebook開發(fā)者開發(fā)

2010-10-09 09:20:08

.NET

2016-05-18 10:15:25

PythonNode.js

2012-02-28 09:11:51

語(yǔ)言Lua

2020-07-17 14:06:36

Scrum敏捷團(tuán)隊(duì)

2025-03-21 10:33:22

2012-04-04 22:07:12

Android

2024-03-12 00:00:00

RocketMQ服務(wù)端磁盤

2022-04-21 08:20:33

CPU換蓋CPU

2020-06-19 08:01:48

Kotlin 協(xié)程編程

2013-10-22 15:18:19

2014-01-09 09:24:40

2014-01-17 14:39:18

12306 搶票

2015-03-02 15:13:52

Apple Watch

2012-06-18 14:51:09

Python

2015-06-04 11:22:22

前端程序員
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)