CSS 陰影動畫優化技巧一則

原文: CSS 陰影動畫優化技巧一則

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

本文不是直譯,由於以爲這個技巧頗有意思頗有用,遂起一文。html

box-shaodw 在咱們的工做中使用以及愈來愈多,伴隨陰影的動畫或多或少都有一點。假設,咱們有下面這樣一個盒子:git

?
1
2
3
4
5
div {
     width : 100px ;
     height : 100px ;
     box-shadow: 0 2px 4px rgba( 0 , 0 , 0 , 0.3 );
}

但願 hover 的時候,盒陰影從 box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3) 過渡到 box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3)github

  • box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3) --> box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3)

OK,最簡單的方法固然是:瀏覽器

?
1
2
3
4
div:hover {
     width : 100px ;
     box-shadow: 0 5px 15px rgba( 0 , 0 , 0 , 0.3 );
}

由於過渡動畫是在兩個不一樣的盒陰影狀態在發生,因此在過渡動畫的時間內,瀏覽器會不斷的重繪盒陰影。而又因爲陰影屬於耗性能樣式,因此這種動畫給人的感受多少有些卡頓。微信

這裏有一個小技巧能夠優化這種狀況下的陰影動畫。性能

 

使用僞元素及透明度進行優化

使用僞元素及透明度進行優化,咱們給上述元素添加一個 before 僞元素,大小與父 div 一致,而且提早給這個元素添加好所須要的最終的盒陰影狀態,可是元素的透明度爲 0。微信支付

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
div {
     position : relative ;
     width : 100px ;
     height : 100px ;
     box-shadow: 0 2px 4px rgba( 0 , 0 , 0 , 0.3 );
}
 
div::before {
     content : "" ;
     position : absolute ;
     top : 0 ;
     left : 0 ;
     width : 100% ;
     height : 100% ;
     box-shadow: 0 5px 15px rgba( 0 , 0 , 0 , 0.3 );
     opacity: 0 ;
}

而後,在 hover 的時候,咱們只須要將僞元素的透明度從 0 設置爲 1 便可。優化

?
1
2
3
div:hover::before {
     opacity: 1 ;
}

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

bshadow

爲何對透明度 opacity 進行動畫要比對 box-shadow 進行動畫性能更好呢?能夠看看這裏這張表格,列舉了不一樣屬性變換對頁面重排、重繪的影響:

image

very few CSS properties

最後,Demo 能夠看看:

 

CodePen Demo -- 優化box-shadow動畫

 

存在的問題,另一種方案

原文中上述這個方案其實並不算太完美,由於最終的效果是兩個陰影的疊加效果,可能會在總體的感受上陰影顏色更深了一點。

因此須要對最終狀態的陰影進行微調一下,削弱一點效果,儘可能讓兩個陰影的疊加效果與單一一個陰影效果相近。

固然,咱們能夠再對上述方案進行優化,咱們再使用一個 ::after 僞元素,::after 僞元素設置爲初始狀態且透明度爲1,::before 僞元素設置爲末尾狀態且透明度爲0:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
div {
     position : relative ;
     width : 100px ;
     height : 100px ;
}
 
div::before {
     box-shadow: 0 5px 15px rgba( 0 , 0 , 0 , 0.3 );
     opacity: 0 ;
}
 
div::after {
     box-shadow: 0 2px 4px rgba( 0 , 0 , 0 , 0.3 );
}

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

?
1
2
3
4
5
6
7
div:hover::before {
     opacity: 1 ;
}
 
div:hover::after {
     opacity: 0 ;
}

bshadow2

CodePen Demo -- 優化box-shadow動畫

最後

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

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

最後,新開通的公衆號求關注,形式但願是更短的篇幅,質量更高一些的技巧類文章,包括但不侷限於 CSS:

image

若是以爲文章對您有用,請隨意打賞。您的支持將鼓勵我繼續創做!
打賞支持
+

(^_^)打個賞喝個咖啡(^_^)

微信支付
支付寶支付
相關文章
相關標籤/搜索