溫馨提示×

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

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

web前端入門(mén)到實(shí)戰(zhàn):CSS 陰影動(dòng)畫(huà)優(yōu)化技巧

發(fā)布時(shí)間:2020-07-19 12:09:38 來(lái)源:網(wǎng)絡(luò) 閱讀:217 作者:前端向南 欄目:web開(kāi)發(fā)

box-shaodw 在我們的工作中使用以及越來(lái)越多,伴隨陰影的動(dòng)畫(huà)或多或少都有一點(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);
}
web前端開(kāi)發(fā)學(xué)習(xí)Q-q-u-n: 731771211,分享學(xué)習(xí)的方法和需要注意的小細(xì)節(jié),不停更新最新的教程和學(xué)習(xí)方法(詳細(xì)的前端項(xiàng)目實(shí)戰(zhàn)教學(xué)視頻,PDF)

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

這里有一個(gè)小技巧可以?xún)?yōu)化這種情況下的陰影動(dòng)畫(huà)。

使用偽元素及透明度進(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)畫(huà)的流暢程度,讓它看起來(lái)更加絲滑。

web前端入門(mén)到實(shí)戰(zhàn):CSS 陰影動(dòng)畫(huà)優(yōu)化技巧

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

web前端入門(mén)到實(shí)戰(zhàn):CSS 陰影動(dòng)畫(huà)優(yōu)化技巧

存在的問(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);
}
web前端開(kāi)發(fā)學(xué)習(xí)Q-q-u-n: 731771211,分享學(xué)習(xí)的方法和需要注意的小細(xì)節(jié),不停更新最新的教程和學(xué)習(xí)方法(詳細(xì)的前端項(xiàng)目實(shí)戰(zhàn)教學(xué)視頻,PDF)

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

div:hover::before {
    opacity: 1;
}

div:hover::after {
    opacity: 0;
}
向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)容。

AI