天天看點

CSS 陰影動畫優化技巧一則

本技巧來自這篇文章 -- How to animate box-shadow with silky smooth performance

本文不是直譯,因為覺得這個技巧很有意思很有用,遂起一文。

<code>box-shadow</code> 在我們的工作中使用以及越來越多,伴随陰影的動畫或多或少都有一點。假設,我們有下面這樣一個盒子:

希望 hover 的時候,盒陰影從 <code>box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3)</code> 過渡到 <code>box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3)</code>。

<code>box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3)</code> --&gt; <code>box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3)</code>

OK,最簡單的方法當然是:

因為過渡動畫是在兩個不同的盒陰影狀态在發生,是以在過渡動畫的時間内,浏覽器會不斷的重繪盒陰影。而又由于陰影屬于耗性能樣式,是以這種動畫給人的感覺多少有些卡頓。

這裡有一個小技巧可以優化這種情況下的陰影動畫。

使用僞元素及透明度進行優化,我們給上述元素添加一個 before 僞元素,大小與父 div 一緻,并且提前給這個元素添加好所需要的最終的盒陰影狀态,但是元素的透明度為 0。

然後,在 hover 的時候,我們隻需要将僞元素的透明度從 0 設定為 1 即可。

這樣做的好處是,實際在進行的陰影變化,其實隻是透明度的變化,而沒有對陰影進行不斷的重繪,有效的提升了陰影動畫的流暢程度,讓它看起來更加絲滑。

CSS 陰影動畫優化技巧一則

為什麼對透明度 <code>opacity</code> 進行動畫要比對 <code>box-shadow</code> 進行動畫性能更好呢?可以看看這裡這張表格,列舉了不同屬性變換對頁面重排、重繪的影響:

CSS 陰影動畫優化技巧一則

very few CSS properties

最後,Demo 可以看看:

CodePen Demo -- 優化box-shadow動畫

原文中上述這個方案其實并不算太完美,因為最終的效果是兩個陰影的疊加效果,可能會在整體的感覺上陰影顔色更深了一點。

是以需要對最終狀态的陰影進行微調一下,削弱一點效果,盡量讓兩個陰影的疊加效果與單一一個陰影效果相近。

當然,我們可以再對上述方案進行優化,我們再使用一個 <code>::after</code> 僞元素,<code>::after</code> 僞元素設定為初始狀态且透明度為1,<code>::before</code> 僞元素設定為末尾狀态且透明度為0:

實際 hover 的時候,對兩個僞元素進行一顯一隐,這樣最終的效果隻有一個陰影效果,沒有陰影的疊加,與直接對陰影進行過渡變化效果一緻:

CSS 陰影動畫優化技巧一則

好了,本文到此結束,希望對你有幫助 :)

更多精彩 CSS 技術文章彙總在我的 Github -- iCSS ,持續更新,歡迎點個 star 訂閱收藏。