CSS 陰影動(dòng)畫優(yōu)化技巧

本技巧來自這篇文章 --How to animate box-shadow with silky smooth performance
本文不是直譯,因?yàn)橛X得這個(gè)技巧很有意思很有用,遂起一文。
box-shaodw
在我們的工作中使用以及越來越多,伴隨陰影的動(dòng)畫或多或少都有一點(diǎn)。假設(shè),我們有下面這樣一個(gè)盒子:
div { width: 100px; height: 100px; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3); }
希望 hover 的時(shí)候,盒陰影從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,最簡單的方法當(dāng)然是:
div:hover { width: 100px; box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3); }
因?yàn)檫^渡動(dòng)畫是在兩個(gè)不同的盒陰影狀態(tài)在發(fā)生,所以在過渡動(dòng)畫的時(shí)間內(nèi),瀏覽器會(huì)不斷的重繪盒陰影。而又由于陰影屬于耗性能樣式,所以這種動(dòng)畫給人的感覺多少有些卡頓。
這里有一個(gè)小技巧可以優(yōu)化這種情況下的陰影動(dòng)畫。
使用偽元素及透明度進(jìn)行優(yōu)化
使用偽元素及透明度進(jìn)行優(yōu)化,我們給上述元素添加一個(gè) before 偽元素,大小與父 div 一致,并且提前給這個(gè)元素添加好所需要的最終的盒陰影狀態(tài),但是元素的透明度為 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 的時(shí)候,我們只需要將偽元素的透明度從 0 設(shè)置為 1 即可。
div:hover::before { opacity: 1; }
這樣做的好處是,實(shí)際在進(jìn)行的陰影變化,其實(shí)只是透明度的變化,而沒有對(duì)陰影進(jìn)行不斷的重繪,有效的提升了陰影動(dòng)畫的流暢程度,讓它看起來更加絲滑。
為什么對(duì)透明度opacity
進(jìn)行動(dòng)畫要比對(duì)box-shadow
進(jìn)行動(dòng)畫性能更好呢?可以看看這里這張表格,列舉了不同屬性變換對(duì)頁面重排、重繪的影響:
最后,Demo 可以看看:
CodePen Demo -- 優(yōu)化box-shadow動(dòng)畫
存在的問題,另外一種方案
原文中上述這個(gè)方案其實(shí)并不算太完美,因?yàn)樽罱K的效果是兩個(gè)陰影的疊加效果,可能會(huì)在整體的感覺上陰影顏色更深了一點(diǎn)。
所以需要對(duì)最終狀態(tài)的陰影進(jìn)行微調(diào)一下,削弱一點(diǎn)效果,盡量讓兩個(gè)陰影的疊加效果與單一一個(gè)陰影效果相近。
當(dāng)然,我們可以再對(duì)上述方案進(jìn)行優(yōu)化,我們?cè)偈褂靡粋€(gè)::after
偽元素,::after
偽元素設(shè)置為初始狀態(tài)且透明度為1,::before
偽元素設(shè)置為末尾狀態(tài)且透明度為0:
實(shí)際 hover 的時(shí)候,對(duì)兩個(gè)偽元素進(jìn)行一顯一隱,這樣最終的效果只有一個(gè)陰影效果,沒有陰影的疊加,與直接對(duì)陰影進(jìn)行過渡變化效果一致:
CodePen Demo -- 優(yōu)化box-shadow動(dòng)畫
總結(jié)
以上所述是小編給大家介紹的CSS 陰影動(dòng)畫優(yōu)化技巧,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
相關(guān)文章
JS+css3實(shí)現(xiàn)帶陰影可點(diǎn)擊旋轉(zhuǎn)的3D立體杯子效果源碼
這是一款基于JS+css3實(shí)現(xiàn)帶陰影可點(diǎn)擊旋轉(zhuǎn)的3D立體杯子效果源碼。畫面上依次擺放著白、紅、藍(lán)三個(gè)顏色的杯子,點(diǎn)擊各個(gè)杯子可看到杯子原地轉(zhuǎn)動(dòng),并且顯露出杯子背面的圖案2019-10-15CSS陰影效果的比較之drop-Shadow與box-Shadow
這篇文章主要介紹了CSS陰影效果的比較之drop-Shadow與box-Shadow,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小2019-05-23- 這篇文章主要介紹了CSS 翹邊陰影的實(shí)現(xiàn)代碼的相關(guān)資料,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-06-15
- 我們?cè)跒g覽網(wǎng)頁的時(shí)候,有些時(shí)候會(huì)看到某些區(qū)塊或者某些圖片邊框家里炫酷的陰影,本篇文章主要介紹了CSS 曲線陰影實(shí)現(xiàn)的示例代碼,感興趣的小伙伴們可以參考一下2018-06-15
- 這篇文章主要介紹了css實(shí)現(xiàn)懸浮效果的陰影的方法示例的相關(guān)資料,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-03-23
- 這篇文章主要介紹了css實(shí)現(xiàn)多邊形和梯形盒陰影技巧的相關(guān)資料,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-03-20
- 本文通過實(shí)例代碼給大家介紹了CSS中使用文本陰影與元素陰影效果,代碼簡單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2020-01-18