本技巧來自這篇文章 -- How to animate box-shadow with silky smooth performance
本文不是直譯,因為覺得這個技巧很有意思很有用,遂起一文,
box-shadow 在我們的作業中使用以及越來越多,伴隨陰影的影片或多或少都有一點,假設,我們有下面這樣一個盒子:
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),
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3)-->box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3)
OK,最簡單的方法當然是:
div:hover {
width: 100px;
box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3);
}
因為過渡影片是在兩個不同的盒陰影狀態在發生,所以在過渡影片的時間內,瀏覽器會不斷的重繪盒陰影,而又由于陰影屬于耗性能樣式,所以這種影片給人的感覺多少有些卡頓,
這里有一個小技巧可以優化這種情況下的陰影影片,
使用偽元素及透明度進行優化
使用偽元素及透明度進行優化,我們給上述元素添加一個 before 偽元素,大小與父 div 一致,并且提前給這個元素添加好所需要的最終的盒陰影狀態,但是元素的透明度為 0,
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 即可,
div:hover::before {
opacity: 1;
}
這樣做的好處是,實際在進行的陰影變化,其實只是透明度的變化,而沒有對陰影進行不斷的重繪,有效的提升了陰影影片的流暢程度,讓它看起來更加絲滑,

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

very few CSS properties
最后,Demo 可以看看:
CodePen Demo -- 優化box-shadow影片
存在的問題,另外一種方案
原文中上述這個方案其實并不算太完美,因為最終的效果是兩個陰影的疊加效果,可能會在整體的感覺上陰影顏色更深了一點,
所以需要對最終狀態的陰影進行微調一下,削弱一點效果,盡量讓兩個陰影的疊加效果與單一一個陰影效果相近,
當然,我們可以再對上述方案進行優化,我們再使用一個 ::after 偽元素,::after 偽元素設定為初始狀態且透明度為1,::before 偽元素設定為末尾狀態且透明度為0:
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 的時候,對兩個偽元素進行一顯一隱,這樣最終的效果只有一個陰影效果,沒有陰影的疊加,與直接對陰影進行過渡變化效果一致:
div:hover::before {
opacity: 1;
}
div:hover::after {
opacity: 0;
}

<iframe title="優化box-shadow影片 " src="https://codepen.io/Chokcoco/embed/zYObVRJ?height=265&theme-id=0&default-tab=result" frameborder="no" scrolling="no" width="320" height="265"></iframe>
CodePen Demo -- 優化box-shadow影片
最后
好了,本文到此結束,希望對你有幫助 :)
更多精彩 CSS 技術文章匯總在我的 Github -- iCSS ,持續更新,歡迎點個 star 訂閱收藏,
轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/113690.html
標籤:Html/Css
下一篇:CSS字體屬性
