国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > CSS > 正文

css3針對移動端卡頓問題的解決(動畫性能優化)

2024-07-11 08:40:18
字體:
來源:轉載
供稿:網友

一、使用css,jquery,canvas制作動畫

1.Canvas

優點:性能好,強大,支持多數瀏覽器(除了IE6、IE7、IE8),畫出來的圖形可以直接保存為 .png 或者 .jpg的圖形;

缺點:依賴于HTML,只能通過腳本繪制圖形,沒有實現動畫的API(依靠事件和定時器更新);由于在 canvas 上以編程方式顯示的文本其實就是位圖,因此搜索爬行器將完全忽略文本。文本內容也無法被屏幕閱讀器識別。

2.css3

優點:簡單且與內容分離、css動畫不觸發layout和paint;(這些屬性的修改不會觸發layout和paint:backface-visibility、opacity、perspective、perspective-origin、transform);

缺點:有瀏覽器兼容性問題、安卓手機會出現卡頓、受排版引擎的限制,與整個頁面的dom結構息息相關。

3.JQuery

優點:沒有兼容性問題

缺點:每一幀,都要進行repaint、recomposite(非常耗時);

總結:在移動端動畫效果上,使用css3動畫要比jquery動畫效率高的多。在安卓手機上表現尤其明顯!所以移動端動畫以css3動畫為優先,jquery只能用來簡單處理應用邏輯。css3動畫是用來給內容布局加上特效的通用解決方案,但是在性能堪憂的移動瀏覽器上很可能會受排版性能所限,達不到理想的效果。而對性能有要求的特定場景,比如游戲,用canvas會有很大的提高。

二、css3在移動端出現卡頓問題

css3制作的動畫在ios上跑的66的,但是在安卓上有時會出現卡頓現象。不妨從下面幾點找找問題。

a、是否導致layout
如果是,盡可能將動畫元素absolute或者fixed化以避免影響文檔樹,以減少重排.

b、是否啟用硬件加速
“用到了CSS3動畫”和“開啟了硬件加速”是兩件事情,雖然前者有可能導致后者。
開啟硬件加速在webkit中有神奇的萬金油:opacity: 1;或者-webkit-backface-visibility: hidden;。

c、是否是有高消耗的屬性(css shadow、gradients、background-attachment: fixed等)
有的話,圖片也是一種選擇。這算得上是用空間換時間的優化了。

d、repaint的面積
如果是,只好縮小動畫面積了。這一步的優化有限;

e、盡量使用 transform 生成動畫,避免使用 height,width,margin,padding 等;如以下例子1和例子2。

PS:使用 transform,瀏覽器只需要一次生成這個元素的位圖,并在動畫開始的時候將它提交給 GPU 去處理 。之后,瀏覽器不需要再做任何布局、 繪制以及提交位圖的操作。從而,瀏覽器可以充分利用 GPU 的特長去快速地將位圖繪制在不同的位置、執行旋轉或縮放處理。簡而言之,transform 動畫由GPU控制,支持硬件加速,并不需要軟件方面的渲染

三、動畫過程有閃爍(一般出現在動畫開始)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 即墨市| 攀枝花市| 鹤庆县| 濮阳县| 璧山县| 鞍山市| 嘉善县| 酉阳| 宜昌市| 星子县| 新营市| 海林市| 宁城县| 闽清县| 临城县| 岗巴县| 黎平县| 嘉禾县| 乌鲁木齐县| 山丹县| 进贤县| 大竹县| 张家口市| 连南| 满城县| 调兵山市| 湘潭县| 武陟县| 准格尔旗| 胶州市| 土默特右旗| 龙州县| 新蔡县| 金湖县| 江孜县| 安仁县| 星子县| 遂溪县| 耒阳市| 江城| 古蔺县|