更新時(shí)間:2021-11-01 來源:黑馬程序員 瀏覽量:
transition-timing-function屬性規(guī)定過渡效果的速度曲線,默認(rèn)值為"ease",其基本語法格式如下。
transition-timing-function:linear|ease|ease-in|ease-out|ease-in-out|cubic-bezier(n,n,n,n);
從上述語法可以看出,transition-timing-function屬性的取值有很多,常見屬性值及說明如下所示。
transition-timing-function屬性值
linear:指定以相同速度開始至結(jié)束的過渡效果,等同于cubic-bezier(0,0,1,1))
ease: 指定以慢速開始,然后加快,最后慢慢結(jié)束的過渡效果,等同于cubic-bezier(0.25,0.1,0.25,1)
ease-in:指定以慢速開始,然后逐漸加快(淡入效果)的過渡效果,等同于cubic-bezier(0.42,0,1,1)
ease-out:指定已慢速結(jié)束(淡出效果)的過渡效果,等于cubic-bezier(0,0,0.58,1)
ease-in-out:指定以慢速開始和結(jié)束的過渡效果,等同于cubic-bezier(0.42,0,0.58,1)
cubic-bezier(n,n,n,n):定義用于加速或者減速的貝賽爾曲線的形狀,它們的值在0~1
下面通過一個(gè)案例來演示transition-timing-function屬性的用法,如下所示:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>transition-timing-function</title> <style> div { width: 200px; height: 200px; margin: 0 auto; background-color: yellow; border: 5px solid red; border-radius: 0px; } div:hover { border-radius: 105px; /* 指定動(dòng)畫過渡的CSS屬性 */ transition-property: border-radius; -webkit-transition-property: border-radius; -moz-transition-property: border-radius; -o-transition-property: border-radius; /* 指定動(dòng)畫過渡時(shí)間 */ transition-duration: 3s; -webkit-transition-duration: 3s; -moz-transition-duration: 3s; -o-transition-duration: 3s; /* 指定動(dòng)畫慢速開始和結(jié)束的過渡效果 */ transition-timing-function: ease-in-out; -webkit-transition-timing-function: ease-in-out; -moz-transition-timing-function: ease-in-out; -o-transition-timing-function: ease-in-out; } </style> </head> <body> <div></div> </body> </html>
上面的案例中,通過transition-property屬性指定產(chǎn)生過渡效果的CSS屬性為“border-radius”,并指定過渡動(dòng)畫由正方形變?yōu)檎龍A形。然后使用transition-duration屬性定義過渡效果需要花費(fèi)5秒的時(shí)間,同時(shí)使用transition-timing-function屬性規(guī)定過渡效果以慢速開始和結(jié)束。
代碼運(yùn)行,當(dāng)鼠標(biāo)指針懸浮到網(wǎng)頁中的<div>區(qū)域時(shí),過渡的動(dòng)作將會(huì)被觸發(fā),正方形將慢速開始變化,然后逐漸加速,隨后慢速變?yōu)檎龍A形,效果如圖所示。
猜你喜歡