JS/jquery實現鼠標控制頁面元素顯隱

最近因爲公司網站要上一個活動廣告橫幅,當用戶鼠標劃過時顯隱二維碼。像這種鼠標事件控制頁面元素顯隱的情況,碼農們會經常遇到,可以通過javascript或jquery代碼實現,下面就幾種常見需求一起歸納一下。

mouseout和mouseleave

這裏需要特別注意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>


效果如下:

fadeIn和fadeOut

前文實例中用的是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實現鼠標事件控制頁面元素顯隱效果,方法十分簡單。如果大家還有更好的其他解決方案,歡迎一起討論交流。





發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章