溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

CSS陰影動(dòng)畫優(yōu)化的方法

發(fā)布時(shí)間:2022-02-25 16:48:18 來(lái)源:億速云 閱讀:192 作者:iii 欄目:web開發(fā)

這篇文章主要介紹了CSS陰影動(dòng)畫優(yōu)化的方法的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡(jiǎn)單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇CSS陰影動(dòng)畫優(yōu)化的方法文章都會(huì)有所收獲,下面我們一起來(lái)看看吧。

  box-shaodw 在我們的工作中使用以及越來(lái)越多,伴隨陰影的動(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) 過(guò)渡到 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,最簡(jiǎn)單的方法當(dāng)然是:

  div:hover {

  width: 100px;

  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3);

  因?yàn)檫^(guò)渡動(dòng)畫是在兩個(gè)不同的盒陰影狀態(tài)在發(fā)生,所以在過(guò)渡動(dòng)畫的時(shí)間內(nèi),瀏覽器會(huì)不斷的重繪盒陰影。而又由于陰影屬于耗性能樣式,所以這種動(dòng)畫給人的感覺(jué)多少有些卡頓。

  這里有一個(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í)只是透明度的變化,而沒(méi)有對(duì)陰影進(jìn)行不斷的重繪,有效的提升了陰影動(dòng)畫的流暢程度,讓它看起來(lái)更加絲滑。

  為什么對(duì)透明度 opacity 進(jìn)行動(dòng)畫要比對(duì) box-shadow 進(jìn)行動(dòng)畫性能更好呢?可以看看這里這張表格,列舉了不同屬性變換對(duì)頁(yè)面重排、重繪的影響:

  存在的問(wèn)題,另外一種方案

  原文中上述這個(gè)方案其實(shí)并不算太完美,因?yàn)樽罱K的效果是兩個(gè)陰影的疊加效果,可能會(huì)在整體的感覺(jué)上陰影顏色更深了一點(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:

  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);

  }

  實(shí)際 hover 的時(shí)候,對(duì)兩個(gè)偽元素進(jìn)行一顯一隱,這樣最終的效果只有一個(gè)陰影效果,沒(méi)有陰影的疊加,與直接對(duì)陰影進(jìn)行過(guò)渡變化效果一致:

  div:hover::before {

  opacity: 1;

  }

  div:hover::after {

  opacity: 0;

  }

關(guān)于“CSS陰影動(dòng)畫優(yōu)化的方法”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對(duì)“CSS陰影動(dòng)畫優(yōu)化的方法”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

css
AI