css屬性的選擇對動畫性能的影響

来源:http://www.cnblogs.com/8hao/archive/2016/03/07/5251123.html
-Advertisement-
Play Games

原文出處: 攜程設計委員會 現在手機的占比越來越高,各種酷炫頁面層出不窮,這些特效都離不開css動畫。說到css動畫,主流的情況也就無非這兩大類:位移和形變。而我們在寫一個動畫特效的過程中,如何去提升它的性能呢?當然首先我們需要去瞭解一下基本的概念,比如瀏覽器渲染的工作原理等,這些我也在讀了幾位大牛


原文出處: 攜程設計委員會 

現在手機的占比越來越高,各種酷炫頁面層出不窮,這些特效都離不開css動畫。說到css動畫,主流的情況也就無非這兩大類:位移和形變。而我們在寫一個動畫特效的過程中,如何去提升它的性能呢?當然首先我們需要去瞭解一下基本的概念,比如瀏覽器渲染的工作原理等,這些我也在讀了幾位大牛寫的相關文章後才有了一定的瞭解,這邊我也不細說了,有興趣的同學可以去瞭解一下。本次的目的簡單粗暴地講,其實就是我們應該使用什麼css屬性去進行動畫的繪製時,能夠有效的提高瀏覽器在渲染和繪製過程中的性能。

快速進入主題,大家先來看個demo。我分別使用了left和transform在2秒內向右平移了500px的位移。代碼如下:

   
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 <style> .box-ps,.box-tf{position:absolute;top:0;left:0;width:100px;height:100px;background-color:red;} .box-ps{-webkit-animation:box-ps 2s linear;} .box-tf{-webkit-animation:box-tf 2s linear;}   @-webkit-keyframes box-ps{ 0%{ left:0; }100%{ left:500px; } }   @-webkit-keyframes box-tf{ 0%{ -webkit-transform:translate(0,0); }100%{ -webkit-transform:translate(500px,0); } } </style>   <body> <div class="box-ps"></div> <div class="box-tf"></div> </body>

然後在chrome下得到瞭如下的結果,第一張為使用left的截圖,第二張為使用transform的截圖:

ps

tf

顯而易見,我們在幀模式這裡可以看到left比transform幀數要低,而且在渲染和繪製這邊的耗時,left要遠遠的大於transform。看到這裡,相信大家心裡已經有結論了。
我們再利用chrome的show paint rectangles來觀察一下兩者在動畫過程中,渲染和繪製的區域有何差異,第一張為使用left的截圖,第二張為使用transform的截圖:

ps

tf

我們可以看到,使用left寫的整個動畫過程中,瀏覽器一直在進行繪製處理。而相對而言,使用transform時,僅僅是在動畫開始和結束是進行了繪製。因此,對於動畫的性能上,transform要更為出色。至於原因,這裡就要引入一個觸發重新佈局的概念:

我們在改變一些屬性時,如果是跟layout相關的屬性,則會觸發重新佈局,導致渲染和繪製所需要的時間將會更長。因此,我們在寫動畫的時候因該規避這些屬性:width, height, margin, padding, border, display, top, right, bottom ,left, position, float, overflow等。
不會出發重新佈局的屬性有:transform(其中的translate, rotate, scale), color, background等。

所以,我們平時在寫css動畫時,應該優先使用不觸發重新佈局的屬性,這樣可以使我們所展示動畫效果的更加流暢。

問啊-定製化IT教育平臺,牛人一對一服務,有問必答,開發編程社交頭條 官方網站:www.wenaaa.com

QQ群290551701 聚集很多互聯網精英,技術總監,架構師,項目經理!開源技術研究,歡迎業內人士,大牛及新手有志於從事IT行業人員進入!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 背景:在前端開發中,有時會為頁面綁定resize事件,或為一個頁面元素拖拽事件(其核心就是綁定mousemove)在一個正常操作中也有可能在一個短時間內觸發非常多次事件綁定程式,而DOM操作是很消耗性能的,如果為這些事件綁定一些操作DOM節點的操作的話就會引發大量的計算,在用戶看來頁面可能就一時間沒
  • 講述了javascript主要由ECMAScript、DOM、BOM組成
  • 問題1: 使用連續賦值後面的變數會成為全局對象的一個屬性,並且這個屬性可以通過delete刪除。 原因:賦值語句是從右往左執行的,我們將10賦值給了c,但是c此時還聲明,接著把c的返回值賦值給了b,但是b也還沒有聲明,最後賦值給了a此時a有聲明,所以a就是局部變數。 var a = b = c =
  • (第一篇博文) 今天在一個交流群里見他們無聊,然後找到之前收藏的一些c語言題目放出去想讓他們做,結果反倒是自己不會做,於是花了很多時間去想。 原題:張三說李四在說謊,李四說王五在說謊,王五說張三和李四都在說謊。現在問:這三人中到底誰說的是真話,誰說的是假話? 其實問題本身並不難,只是一開始想多了,陷
  • 瞭解RegExp類型: ECMAScript通過RegExp類型來支持正則表達式。 var expression=/pattern/flags; 正則表達式的模式(pattern)部分: 可以是任何簡單或複雜的正則表達式,可以包含字元類,限定符,分組,向前查找,反向引用。 關於正則表達式中各種特殊字
  • 本文同步至微信公眾號http://mp.weixin.qq.com/s?__biz=MzAxMzgwNDU3Mg==&mid=401950045&idx=1&sn=cec056802bb52f909554691d0427f4f0#rd 對後續文章感興趣的可以掃碼關註哈 對於一個非技術人員比如說pm,
  • 效果預覽:http://hovertree.com/code/run/css/x8l6si70.html 請實用Chrome瀏覽器查看效果,手機上也可以. 代碼如下: <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" cont
  • Node.js寫文件的三種方式: 1、通過管道流寫文件 採用管道傳輸二進位流,可以實現自動管理流,可寫流不必當心可讀流流的過快而崩潰,適合大小文件傳輸(推薦) 2 var readStream = fs.createReadStream(decodeURIComponent(root + filep
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...