欧美亚洲综合图区在线|天天射天天干国产成卜|99久久免费国产精精品|国产的欧美一区二区三区|日韩中文字幕无码不卡专区|亚麻成人aV极品一区二区|国产成人AV区一区二区三|成人免费一区二区三区视频网站

當(dāng)前位置:首頁 > APP資源 > 正文內(nèi)容

html5為什么可以開發(fā)app(h5能開發(fā)app嗎)

APP資源1個月前 (11-20)187

今天長沙網(wǎng)站建設(shè)公司善微科技要告訴大家的知識是html5app與app的差距。

1、動畫

動畫有很多種,比如側(cè)邊欄菜單的滑入滑出、元素的響應(yīng)動畫、頁面切換之間的過場等等,在H5之下的眾多實現(xiàn)方法都沒有辦法達(dá)到純原生的性能。一般這些的話有幾種不同的選擇:css3動畫、java動畫、原生動畫。

css3動畫非常的消耗性能,如果某一個元素用到css3動畫可能還看不出來,但大面積或過場使用css3動畫會讓app低端手機體驗非常差。最好的選擇一般是通過框架調(diào)用底層的動畫,但不管怎么樣等于在原來的代碼上包上了一層,性能還是不可避免的受到影響。

比如在一個新頁面的載入上,如果調(diào)用底層動畫要考慮的問題有兩個,一個是本身資源頁面的渲染問題,另一個是遠(yuǎn)程數(shù)據(jù)的獲取。即便是這些動畫能夠很快的響應(yīng),但大量的css頁面會導(dǎo)致渲染卡頓,滑入時可能會有白屏/機器卡頓的現(xiàn)象。為了解決這些性能問題又必須要用到預(yù)加載或模擬動畫。即便是這樣,滑入滑出的動畫在低端的安卓機器上還是有很多問題,如果獲取服務(wù)端數(shù)據(jù)處理的方式不合適,卡頓白屏的現(xiàn)象會更嚴(yán)重。具體看下面的數(shù)據(jù)獲取方式。

2、獲取服務(wù)端數(shù)據(jù)

首先要接受的是,這里的數(shù)據(jù)獲取都是在資源頁面上異步完成的,因為只有這樣才能讓這些資源頁面完成預(yù)加載或者渲染。但是異步拿到的數(shù)據(jù)在填入頁面中時可能會涉及DOM操作,眾所周知,DOM操作非常消耗性能,如果頁面小還好,頁面稍大數(shù)據(jù)稍微復(fù)雜一點,頻繁的DOM操作會導(dǎo)致明顯的閃白。而且最重要的一點是,如果頁面加載進(jìn)來之后數(shù)據(jù)更新的速度太慢,也會讓頁面模板等待很長時間,對用戶體驗又不友好,總不能每次打開都像瀏覽器一樣等待刷新是吧。

這個問題如果沒有得到解決,H5APP是很難承擔(dān)大規(guī)模數(shù)據(jù)的頁面,在它們之中頻繁切換更是難上加難,那么肯定有人也會想到用MVVM的方式,其實我也寫過一些基于MVVM的H5APP,相對來說它們獲取數(shù)據(jù)和更新數(shù)據(jù)的方式更敏捷更科學(xué),但寫的過程中又要注意很多H5獨有的問題,這些問題在下面的頁面切換里來講。

3、頁面切換

html5為什么可以開發(fā)app(h5能開發(fā)app嗎)

上面我們看到了幾種不錯的實現(xiàn)方式,比如預(yù)加載和模擬動畫,甚至有批量的預(yù)加載,批量的截圖模擬動畫等等,雖然看起來很友好解決了不少問題,但事實上如果頁面足夠多就會引發(fā)另一個問題——頁面的生存周期。

試想一下,如果引導(dǎo)頁或者主頁面緩存了5個子頁面的資源,在跳轉(zhuǎn)到響應(yīng)的子頁面時又會緩存這些子頁面的下級頁面資源,如此反復(fù)肯定會占據(jù)大量內(nèi)存使APP的體驗下降。那么怎么知道那些頁面是需要的,最多緩存多少頁面,什么時候結(jié)束哪些頁面的生存周期呢?在我用過的很多H5APP的框架里都沒有對這些問題有一個完美的解答,因此在頁面較多內(nèi)容較多的APP中可能會因這些資源分配的問題降低性能。

這時候我們回過頭來再看看MVVM的數(shù)據(jù)加載問題,實際上不管哪個MVVM框架,寫過的人都知道管理這種新型的前端代碼最重要的問題是內(nèi)存的問題,你既要保證代碼寫的足夠優(yōu)雅沒有任何內(nèi)存泄露問題,也要考慮到在頁面生存周期結(jié)束時它們的控制器/頁面資源是否得到釋放,這對全局有沒有什么影響,在多個請求時也要合理的分配資源,甚至是復(fù)用這些父級頁面?zhèn)鬟^來的緩存資源等等。較小的APP可能并不會有這些問題,如果你想用純H5來開發(fā)大型APP,這很可能會浪費你很多時間——而且結(jié)果還不會讓你滿意。

4、Android/iOS的區(qū)別

很多人都說純H5APP一次編寫就能編譯Android/iOS兩種不同的APP,大大降低了成本。實際上這個觀點本身就是值得懷疑的,如果你寫過這類APP就能明白我在說什么,它們既不省事,又存在很多BUG,調(diào)試時尤其繁瑣。舉一個很簡單的例子,Android和iOS在返回上一頁的處理方式上就有明顯的區(qū)別,iOS的頂部bar在全屏下怎樣處理,Android機器出現(xiàn)smart bar怎樣處理頁面的布局,調(diào)用底層硬件時怎樣區(qū)分不同的場景等等,你需要寫一個又一個機型和系統(tǒng)的判斷,然后分別在Android和iOS下調(diào)試,最后你卻發(fā)現(xiàn)這并沒有卵用,累的要死卻什么沒學(xué)到,只有一堆不知道什么時候會過時的經(jīng)驗。

現(xiàn)在做H5混合APP開發(fā)的人很多,但是純H5卻很年輕,很多問題都沒有很好的解決,這幾個是我在做這些APP時考慮最多的問題。當(dāng)然大家也不必?fù)?dān)心,隨著ES6的推行,硬件發(fā)展越來越快,純H5APP未必沒有一席之地。最后說一個很少人注意到的H5優(yōu)勢,大家大談H5APP時都是快速開發(fā)、低成本、多平臺等等,但我卻覺得它和很多APP開發(fā)方式相比有一個不同之處——圖文混合的排版。正是這些復(fù)雜多變的CSS樣式消耗了性能,但是它帶來了排版的多樣性,能夠細(xì)致到每一個字寬行高和風(fēng)格的像素級處理,才是H5的優(yōu)異之處。

掃描二維碼推送至手機訪問。

版權(quán)聲明:本文由飛速云SEO網(wǎng)絡(luò)優(yōu)化推廣發(fā)布,如需轉(zhuǎn)載請注明出處。

本文鏈接:http://landcheck.net/post/124139.html

“html5為什么可以開發(fā)app(h5能開發(fā)app嗎)” 的相關(guān)文章

武漢app定制開發(fā)公司(武漢app定制開發(fā)公司怎么樣)

武漢app定制開發(fā)公司(武漢app定制開發(fā)公司怎么樣)

1華盛恒輝科技有限公司 上榜理由華盛恒輝是一家專注于高端軟件定制開發(fā)服務(wù)和高端建設(shè)的服務(wù)機構(gòu),致力于為企業(yè)提供全面系統(tǒng)的開發(fā)制作方案在開發(fā)建設(shè)到運營推廣領(lǐng)域擁有豐富經(jīng)驗,在教育,醫(yī)療,APP,管理,商城,人工。 三整體評估選擇開發(fā)公司,一定要進(jìn)行整體評估,一是評估自身,二是評估對方四跟進(jìn)速度好的AP...

網(wǎng)站類app(網(wǎng)站類型有哪些)

網(wǎng)站類app(網(wǎng)站類型有哪些)

1、2旅游app排行榜前十名3旅游的app有哪些4旅游攻略app排行榜前十名口碑最好的旅游軟件有哪些?口碑好的旅游軟件去哪兒攜程旅行窮游驢媽媽旅游螞蜂窩自由行一去哪兒去哪兒APP是國內(nèi)較大的一家旅游出行APP,上面有旅游。 2、2AppmakriOS,WindowsPhone,AndroidAppM...

做企業(yè)規(guī)劃的app(做企業(yè)規(guī)劃的步驟有哪些)

做企業(yè)規(guī)劃的app(做企業(yè)規(guī)劃的步驟有哪些)

十大室內(nèi)設(shè)計培訓(xùn)機構(gòu)排行榜 現(xiàn)在室內(nèi)設(shè)計的門檻越來越低,越來越考驗設(shè)計師的能力,想要讓自己的技術(shù)精益求精,想在預(yù)計的時間內(nèi)學(xué)到真本領(lǐng),則選擇去正規(guī)學(xué)校進(jìn)行專業(yè)的學(xué)習(xí)。因為專業(yè)的室內(nèi)培訓(xùn)學(xué)校可以給學(xué)員進(jìn)行更加正規(guī)的培訓(xùn),比如杭州清風(fēng)室內(nèi)設(shè)計培訓(xùn)學(xué)院,專攻室內(nèi)設(shè)計一門專業(yè),老師都是股份責(zé)任制,培訓(xùn)班進(jìn)行...

優(yōu)秀的app首頁設(shè)計樣式(優(yōu)秀的app首頁設(shè)計樣式有哪些)

優(yōu)秀的app首頁設(shè)計樣式(優(yōu)秀的app首頁設(shè)計樣式有哪些)

UI設(shè)計必要知道的APP頁面 一起始頁launchscreen說明程序啟動時需要一定的反應(yīng)時間,在這段時間內(nèi)屏幕處于空置狀態(tài),為了讓用戶知道程序已經(jīng)啟動,現(xiàn)在只有一個加載過程,而且也是為了緩解用戶的焦慮,所以用圖片視頻代替;回答目前互聯(lián)發(fā)展勢頭越來越好,app應(yīng)用也是日益增多,因此app的引導(dǎo)頁設(shè)計...

app軟件開發(fā)制作方案(app軟件開發(fā)制作方案怎么做)

app軟件開發(fā)制作方案(app軟件開發(fā)制作方案怎么做)

從最初與客戶了解需求功能到最終的測試上線,一個完整的APP就被開發(fā)出來了如同其他軟件開發(fā)一樣,APP的整個生命周期都是需要緊扣用戶需求的,一旦脫離用戶需求,就極可能開發(fā)出質(zhì)量差用戶不認(rèn)可的APP軟件,這是許多APP開發(fā);就可以聯(lián)網(wǎng)進(jìn)行系統(tǒng)內(nèi)測,參與人員包括項目需求方和開發(fā)公司測試人員,可以下載并安裝...

app和wap設(shè)計(app與web模式有何區(qū)別與聯(lián)系)

app和wap設(shè)計(app與web模式有何區(qū)別與聯(lián)系)

1一屏一個任務(wù) 降低用戶完成任務(wù)之時所需耗費的精力你為APP的每一屏都應(yīng)當(dāng)承載一個對用戶有用有價值的交互或者任務(wù),一次完成一個任務(wù),且只能有一個任務(wù),其中應(yīng)該不包含超過1次的行為召喚CTA這樣的設(shè)計能讓;正確的名字應(yīng)該是“移動網(wǎng)頁”,這樣比較能夠準(zhǔn)確地概括手機端的網(wǎng)頁設(shè)計因為手機自身的一些特性,所以...

庐江县| 海淀区| 偃师市| 乌兰县| 天津市| 海南省| 黔东| 鱼台县| 北宁市| 广平县| 株洲县| 东海县| 惠水县| 阿克陶县| 徐闻县| 开平市| 盈江县| 台南县| 淮南市| 河曲县| 中超| 怀化市| 建昌县| 锡林郭勒盟| 太白县| 渝北区| 突泉县| 彭阳县| 原平市| 余江县| 麟游县| 西城区| 肃宁县| 尚志市| 巫山县| 鞍山市| 隆化县| 麻栗坡县| 枞阳县| 门源| 九龙坡区|