国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

創建前端平移動畫為何 translate() 優于 top/right/bottom/left

morgan / 1266人閱讀

摘要:許多層還會因為過大與許多內容重疊而導致過度繪制的情況發生,從而增加柵格化的時間。關于這一點,在中也有所體現。

前言

研究這個問題的起因,源于我在閱讀作曲家與聽眾這篇文章時,看到的這樣一句話。

例如,我對很多開發者(不管新手還是老手)仍然使用 CSS 的 top 和 left 而不是 transform 創建平移動畫感到震驚,盡管只要你在除了 8 核 MacBook Pro 之外的設備上進行過測試,就會發現幀率的差別極其明顯。

看到這句話我也同樣震驚,震驚之處正如作者所言,我就是從未在意過兩者差別而使用 top 和 left 創建平移動畫的人之一。那么為什么兩者會有區別,讓我們來一探究竟吧。

測試用例

其實很慚愧,早在2012年就有許多人在博文中闡述這一事實了,也因此,我能很輕松的找到非常棒的demo(來源見參考文獻),如下:

top、left實現基于關鍵幀的平移動畫

translate實現基于關鍵幀的平移動畫

相信讀者在把Macbook Pro增加到一定數量的時候,都能發現兩者之間的差異了吧。

深入背后

現在讓我們來探究其中的原因。打開Chrome dev tools,切到Performance選項,記錄一段時間后,選擇某一幀查看各個過程所占時間。

首先是top、left的時間線:

在這一幀中,我們看到多個步驟占用了CPU時間。

換到translate則變成了截然不同的樣子:

根本沒有CPU時間。我看了很多幀,除了少部分幀有0.1ms左右的腳本執行時間之外,大部分幀的CPU時間都是0。

答案已經很顯然了,使用translate來做平移運動,大部分時間都不需要CPU參與。這個結果和五年前的文章不太相同,但時間已經過了五年,瀏覽器的優化至此地步也不算出乎意料吧。

接下來我們打開Render,開啟Paint Flashing和Layer Borders。

對于top、left我們會看到如下情況:

其中綠框是瀏覽器重繪的區域,對于使用position的情況,瀏覽器要在動畫的執行中不停地繪制綠框中的區域。

而對于transform則是另一幅場景:

我們可以看到transform的版本我們的MacBook圖片周圍會多一個框框,這是因為transform會生成一個新的層,而對這個圖層進行變換,對于瀏覽器來說,是不需要重繪的。包括在我點擊“add 10 more macbook”之后,也只有插入元素的時候會引起重繪。同樣,新插入的“MacBook”也各自有獨立的圖層,不會引起重繪。

那么,Chrome創建層的標準是什么呢?在Accelerated Rendering in Chrome中有如下表述:

What else gets its own layer? Chrome’s heuristics here have evolved over time and continue to, but currently any of the following trigger layer creation:

3D or perspective transform CSS properties

elements with a 3D (WebGL) context or accelerated 2D context

Composited plugins (i.e. Flash)

Elements with CSS animation for their opacity or using an animated transform

Elements with accelerated CSS filters

Element has a descendant that has a compositing layer (in other words if the element has a child element that’s in its own layer)

Element has a sibling with a lower z-index which has a compositing layer (in other words the it’s rendered on top of a composited layer)

所以,對于我們的transform動畫,其符合上述第五條規則中的“using an animated transform”,因此會創建自己獨立的層;同樣,我們也可以根據上述規則來給top、left方案創建獨立的層來減少重繪。

接下來,根據第一條規則,讓我們在top、left示例中的.macbook類上面加上這樣一行css:

transform: translateZ(0);

我們就能看到和translate方案一樣的場景了。

通過查閱資料,我簡單說一下我的理解。Chrome會預先將層的內容繪制成位圖發送給GPU,如果層僅僅是位置與透明度等特定的一些屬性發生變化,而不是內容發生變化,則無需重繪這一位圖。因此無論是translate動畫方案,還是加上3D變換屬性的top、left方案,由于其都在獨立的層上,且只是發生位置變化,因此無需重繪。

然而,層并不是越多越好。參考Accelerated Rendering in Chrome中的表述。

But beware just blindly creating them, as they’re not free: they take up memory in system RAM and on the GPU (particularly limited on mobile devices) and having lots of them can introduce other overhead in the logic keeps track of which are visible. Many layers can also actually increase time spent rasterizing if they layers are large and overlap a lot where they didn’t previously, leading to what’s sometimes referred to as “overdraw”. So use your knowledge wisely!

簡單翻譯一下就是:層會占用系統 RAM 與 GPU(在移動設備上尤其有限)的內存,并且擁有大量的層會因為記錄哪些是可見的而引入額外的開銷。許多層還會因為過大與許多內容重疊而導致“過度繪制(overdraw)”的情況發生,從而增加柵格化的時間。關于這一點,在Jank Busting Apple"s Home Page中也有所體現。

In this case, too many elements have translateZ(0) applied when only one or two applications are really needed. This is forcing a longer composite time and ultimately giving the animations some jank.

“So use your knowledge wisely!”

參考文獻

A Tale of Animation Performance

Why Moving Elements With Translate() Is Better Than Pos:abs Top/left

Accelerated Rendering in Chrome

Jank Busting Apple"s Home Page

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/112309.html

相關文章

  • 2017-07-27 前端日報

    摘要:前端日報精選使用重寫大型應用后,我們想分享一下這八個經驗與交互之技術有贊前端團隊專題之學在數組中查找指定元素基于角色的權限驗證從源碼學習如何寫模板中文譯掘金譯回顧的成功掘金一些有趣的事情布局教程入門指南定位元素古寺比的寺更 2017-07-27 前端日報 精選 使用 React Native 重寫大型 Ionic 應用后,我們想分享一下這八個經驗H5與Native交互之JSBridge...

    shadajin 評論0 收藏0
  • 如何用 html 和 css 畫一拳超人

    摘要:在繪制琦玉的頭像時,最重要的一個屬性就是,我們用它可以畫出圓形橢圓及各種變體。以下的樣式能夠畫出琦玉的臉部形狀在調整后,可畫出眼鼻嘴的形狀介紹屬性也是一個很強大的屬性,能夠對元素做各種變形。 寫這篇博客的起因是我看了Medium上的這篇文章:How I started drawing CSS Images,然后哇哦?,同樣是前端開發,這區別怎么這么大呢?這位作者和我完全點了不同的技能點...

    wuyangchun 評論0 收藏0
  • CSS3 變換

    摘要:概覽變換也叫轉換,主要包括以下幾種旋轉扭曲縮放和移動以及矩陣變形。變換沒有扭曲操作,有移動,旋轉,縮放。三,取消的變換,將變換應用到上并置于縮放前,改變縮放值,沒有任何變化。 概覽 CSS3 變換也叫 2D/3D轉換,主要包括以下幾種:旋轉(rotate) 、扭曲 (skew) 、縮放(scale) 和 移動(translate) 以及 矩陣變形(matrix) 。transform ...

    wayneli 評論0 收藏0
  • 前端培訓-初級階段(5 - 8)

    摘要:前端最基礎的就是。類同于標簽將對象作為彈性伸縮盒顯示。定義了一條立方貝塞爾曲線。是,表示終止時間和終止狀態。動畫過渡可以理解為兩個關鍵幀的補間操作。往期前端培訓初級階段后記年月日更新。參考資料引用培訓目錄出處已備份到筆記速查視差滾動 前端最基礎的就是 HTML+CSS+Javascript。掌握了這三門技術就算入門,但也僅僅是入門,現在前端開發的定義已經遠遠不止這些。前端小課堂(HTM...

    PAMPANG 評論0 收藏0
  • 前端培訓-初級階段(5 - 8)

    摘要:前端最基礎的就是。類同于標簽將對象作為彈性伸縮盒顯示。定義了一條立方貝塞爾曲線。是,表示終止時間和終止狀態。動畫過渡可以理解為兩個關鍵幀的補間操作。往期前端培訓初級階段后記年月日更新。參考資料引用培訓目錄出處已備份到筆記速查視差滾動 前端最基礎的就是 HTML+CSS+Javascript。掌握了這三門技術就算入門,但也僅僅是入門,現在前端開發的定義已經遠遠不止這些。前端小課堂(HTM...

    gaosboy 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<