您好,登錄后才能下訂單哦!
最近因為公司網站要上一個活動廣告橫幅,當用戶鼠標劃過時顯隱二維碼。像這種鼠標事件控制頁面元素顯隱的情況,碼農們會經常遇到,可以通過javascript或jquery代碼實現,下面就幾種常見需求一起歸納一下。
這里需要特別注意mouseout與mouseleave的區別。我們通過下面代碼示例來看一下:
<p style="color:#333333;font-family:-apple-system, " font-size:16px;"="">
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>鼠標控制頁面元素顯隱</title> <script src="http://apps.bdimg.com/libs/jquery/1.11.3/jquery.min.js"></script> <style> #boxout,#boxleave{ width:250px; height:100px; padding-top:20px; background-color:#cccccc; float:left; margin-left:30px; } #boxoutson,#boxleaveson{ width:200px; height:50px; background-color:yellow; padding:0px auto; margin:0px auto; } </style> </head> <body> <div id="boxout"> <div id="boxoutson"> 第<span></span>此觸發mouseout事件 </div> </div> <div id="boxleave"> <div id="boxleaveson"> 第<span></span>此觸發mouseleave事件 </div> </div> <script> x=0; y=0; $("#boxout").mouseout(function() { $("#boxout span").text(x+=1); }); $("#boxleave").mouseleave(function() { $("#boxleave span").text(y+=1); }); </script> </body> </html>
效果如下:
前文實例中用的是show()和hide()方法,前臺顯隱效果瞬間完成,為了提高實際用戶體驗,這里我們介紹兩位更友好的“朋友”,即fadeIn和fadeOut。
fadeIn:方法使用淡入效果來顯示目標元素。
fadeOut:方法使用淡出效果來隱藏目標元素
這兩個方法可以配置參數來控制速度,比如slow、normal、fast或指定毫秒數。
下面我們就show()、hide()與fadeIn()、fadeOut()的效果坐下對比,代碼如下:
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>鼠標控制頁面元素顯隱</title> <script src="http://apps.bdimg.com/libs/jquery/1.11.3/jquery.min.js"></script> <style> #box1,#box2{ width:250px; height:100px; padding-top:20px; background-color:#cccccc; float:left; margin-left:30px; } #box1son,#box2son{ width:200px; height:50px; background-color:yellow; padding:0px auto; margin:0px auto; } </style> </head> <body> <div id="box1"> <div id="box1son"> <span>hide和show</span> </div> </div> <div id="box2"> <div id="box2son"> <span>fadeIn和fadeOut</span> </div> </div> <script> $("#box1 span").hide(); $("#box1").mouseover(function() { $("#box1 span").show(); }).mouseleave(function() { $("#box1 span").hide(); }); $("#box2 span").hide(); $("#box2").mouseover(function() { $("#box2 span").fadeIn("slow"); }).mouseleave(function() { $("#box2 span").fadeOut("slow"); }); </script> </body> </html>
效果如下:
本文我們一起了解學習了通過js或jq實現鼠標事件控制頁面元素顯隱效果,方法十分簡單。如果大家還有更好的其他解決方案,歡迎一起討論交流。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。