由于hover偽類(lèi)添加的動(dòng)畫(huà)效果,僅當(dāng)鼠標(biāo)放在元素上時(shí)會(huì)被觸發(fā),而當(dāng)鼠標(biāo)離開(kāi)時(shí),效果會(huì)中斷,會(huì)顯得很生硬。
大多數(shù)人的想法都是使用js的onmouseover和onmouseleave事件來(lái)實(shí)現(xiàn)動(dòng)畫(huà)效果。其實(shí)不必這么麻煩,CSS3便可以幫你解決這些問(wèn)題。
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>離開(kāi)時(shí)效果生硬</title> <style type="text/css"> div{ width: 100px; height: 100px; border:1px solid; margin:0px auto; margin-top: 200px; } div:hover{ transform: scale(2); transition: all 1s linear; } </style> </head> <body> <div></div> </body> </html>
由于div元素只有在:hover偽類(lèi)觸發(fā)的時(shí)候,效果才能加到div元素上。
當(dāng)鼠標(biāo)離開(kāi)div元素的時(shí)候,:hover偽類(lèi)將不再生效,瞬間丟掉hover里寫(xiě)的動(dòng)畫(huà)效果。
此時(shí),我們應(yīng)當(dāng)在原本元素上再寫(xiě)一個(gè)一模一樣的transition效果,將離開(kāi)斷掉的動(dòng)畫(huà)效果續(xù)接上。
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>簡(jiǎn)單解決</title> <style type="text/css"> div{ width: 100px; height: 100px; border:1px solid; margin:0px auto; margin-top: 200px; /* 在原本元素上再加一個(gè)transition */ transition: all 1s linear; } div:hover{ transform: scale(2); transition: all 1s linear; } </style> </head> <body> <div></div> </body> </html>
此時(shí),不管鼠標(biāo)在什么時(shí)候離開(kāi)元素,都會(huì)原樣返回。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持。
【網(wǎng)站聲明】本站除付費(fèi)源碼經(jīng)過(guò)測(cè)試外,其他素材未做測(cè)試,不保證完整性,網(wǎng)站上部分源碼僅限學(xué)習(xí)交流,請(qǐng)勿用于商業(yè)用途。如損害你的權(quán)益請(qǐng)聯(lián)系客服QQ:2655101040 給予處理,謝謝支持。