日韩精品亚洲精品中文字幕乱伦AV|曰韩区二区三区日韩中文字幕五码|ady99久久人人看人人摸人人|动漫一区二区黄99精品视频在线|AV片在线观看亚洲中文国产精品|伦乱在线VA欧美性爱一二区|亚洲无码mv91热色视频|激情六月综合欧美精品中文

當前位置:首頁 > 軟件開放 > 正文內容

網站菜單欄代碼(web網站 菜單)

軟件開放2個月前 (11-24)213

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

1、動畫

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

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

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

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

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

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

3、頁面切換

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

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

網站菜單欄代碼(web網站 菜單)

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

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

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

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

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

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

本文鏈接:http://www.atlasseeker.com/post/124363.html

分享給朋友:

“網站菜單欄代碼(web網站 菜單)” 的相關文章

系統(tǒng)軟件開發(fā)(區(qū)塊鏈系統(tǒng)軟件開發(fā))

系統(tǒng)軟件開發(fā)(區(qū)塊鏈系統(tǒng)軟件開發(fā))

今天給各位分享系統(tǒng)軟件開發(fā)的知識,其中也會對區(qū)塊鏈系統(tǒng)軟件開發(fā)進行解釋,如果能碰巧解決你現(xiàn)在面臨的問題,別忘了關注本站,現(xiàn)在開始吧!本文目錄一覽: 1、系統(tǒng)軟件開發(fā)公司有哪些 2、軟件開發(fā)包括哪些東西? 3、軟件開發(fā)和系統(tǒng)開發(fā)有什么區(qū)別? 4、軟件開發(fā)工作具體干什么? 系統(tǒng)軟件開發(fā)公司...

第三方交易平臺有哪些主要責任和義務(關于第三方交易平臺的管理規(guī)定)

第三方交易平臺有哪些主要責任和義務(關于第三方交易平臺的管理規(guī)定)

本篇文章給大家談談第三方交易平臺有哪些主要責任和義務,以及關于第三方交易平臺的管理規(guī)定對應的知識點,希望對各位有所幫助,不要忘了收藏本站喔。 本文目錄一覽: 1、第三方在線支付平臺有哪些 2、第三方責任有哪些 3、第三方支付平臺的主要業(yè)務分別是做什么的? 4、目前我國的第三方支付平臺有哪...

源碼編輯器教程視頻建黨一百周年(建黨100周年視頻腳本)

源碼編輯器教程視頻建黨一百周年(建黨100周年視頻腳本)

今天給各位分享源碼編輯器教程視頻建黨一百周年的知識,其中也會對建黨100周年視頻腳本進行解釋,如果能碰巧解決你現(xiàn)在面臨的問題,別忘了關注本站,現(xiàn)在開始吧!本文目錄一覽: 1、java源代碼編輯器 設計用于編寫Java源代碼的編輯器,基本要求:可以完成源程序的文件打開,編輯和文件保存 2、有哪些好...

中央2臺在線直播觀看高清百年信物(中央2臺在線回放觀看百年信物)

中央2臺在線直播觀看高清百年信物(中央2臺在線回放觀看百年信物)

本篇文章給大家談談中央2臺在線直播觀看高清百年信物,以及中央2臺在線回放觀看百年信物對應的知識點,希望對各位有所幫助,不要忘了收藏本站喔。 本文目錄一覽: 1、怎么可以看中央電視臺的直播? 2、《百年中國》免費在線觀看完整版高清,求百度網盤資源 3、下載中央電視臺1一15臺 4、中央電視...

端游游戲交易平臺app排行榜(手游交易平臺app排行榜)

端游游戲交易平臺app排行榜(手游交易平臺app排行榜)

今天給各位分享端游游戲交易平臺app排行榜的知識,其中也會對手游交易平臺app排行榜進行解釋,如果能碰巧解決你現(xiàn)在面臨的問題,別忘了關注本站,現(xiàn)在開始吧!本文目錄一覽: 1、手游交易平臺哪個好 2、賣游戲賬號哪個平臺好? 3、手游交易平臺哪個好? 4、網絡游戲賬號交易平臺哪個比較好?...

女生說可遇不可求是什么意思(女生對男生說可遇不可求是什么意思)

女生說可遇不可求是什么意思(女生對男生說可遇不可求是什么意思)

本篇文章給大家談談女生說可遇不可求是什么意思,以及女生對男生說可遇不可求是什么意思對應的知識點,希望對各位有所幫助,不要忘了收藏本站喔。 本文目錄一覽: 1、你對一個人表白的時候,她和你說“感情的事,是可遇不可求的”是什么意思啊? 2、分手后,女朋友哭著對我說,你是我的可遇不可求,可遇不可留,可...