滑鼠懸浮可以上下伸縮的導航選單

admin發表於2018-07-16

本章節分享一段程式碼例項,它實現了滑鼠懸浮導航選單伸縮的功能。

這種導航選單還是具有一定的實用價值的,需要的朋友可以做一下參考。

程式碼例項如下:

[HTML] 純文字檢視 複製程式碼執行程式碼
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="author" content="http://www.softwhy.com/" />
<title>螞蟻部落</title>
<style>
body{
  margin:0;
  padding:0;
}
#nav li{
  margin:0;
  padding:0;
  display:inline;
  list-style-type:none;
  font-size:12px;
}
#nav a:hover{
  color:#fff;
  background:#FF6A00;
}
#nav a:visited.active, #nav a:link.active{
  background-color:#fff;
  color: #FF6A00;
}
.menu{
  list-style:none;
  margin:0;
  float:right;
}
.menu li{
  float:left;
  margin:0 auto;
  cursor:pointer;
  height:30px;
  padding: 30px 5px 5px 5px;
  margin: 0px 3px 0px 3px;
  border-radius: 0px 0px 10px 10px;
  box-shadow: 0 1px 3px rgba(0,0,0,0.5);
  color:#FFF;
  text-shadow:0 -1px 1px rgba(0,0,0,0.25);
  font-family:"Lucida Grande", Lucida, Verdana, sans-serif;
  font-size: 13px;
  font-weight: bold;
  text-transform: uppercase;
}
</style>
<script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script>
<script type="text/javascript">
(function($){
  $.fn.extend({
    tagdrop: function(options) {
      var defaults = {
        tagPaddingTop: '90px',
        tagDefaultPaddingTop: '30px',
        bgColor: '#B1CCED',
        bgMoverColor: '#7FB0F0',
        textColor: '#e0e0e0',
        textDefaultColor: '#fff'
      };
      var options = $.extend(defaults, options);
      return this.each(function() {
        var obj = $(this);
        var li_items = $("li", obj);
        $("li", obj).css('background-color', options.bgColor);
        li_items.mouseover(function(){
          $(this).animate({paddingTop: options.tagPaddingTop}, 300);
          $(this).css('background-color', options.bgMoverColor);
          $(this).css('color', options.textColor);
        }).mouseout(function() {
          $(this).animate({paddingTop: options.tagDefaultPaddingTop}, 500);
          $("li",$(this).parent()).css('background-color', options.bgColor);
          $("li",$(this).parent()).css('color', options.textDefaultColor);
        });
      });
    }
  });
})(jQuery);
$(document).ready(function() {
  $('.menu').tagdrop({
    tagPaddingTop: '60px',
    bgColor: '#B1CCED',
    bgMoverColor: '#7FB0F0',
    textColor: '#e0e0e0'
  });
});
</script>
</head>
<body>
<ul class="menu">
  <li>About us</li>
  <li>Contacts</li>
  <li>Others</li>
  <li>;Products</li>
  <li>;Portfolio</li>
  <li>Testemonies</li>
</ul>
</body>
</html>

上面的程式碼實現了我們的要求,下面介紹一下它的實現過程。

一.程式碼註釋:

(1).(function($){})(jQuery),一個匿名自執行函式。

(2).$.fn.extend({}),為jquery物件例項擴充套件物件。

(3).tagdrop: function(options) {},一個函式,引數是要傳遞的引數。

(4).var defaults = {

  tagPaddingTop: '90px',

  tagDefaultPaddingTop: '30px',

  bgColor: '#B1CCED',

  bgMoverColor: '#7FB0F0',

  textColor: '#e0e0e0',

  textDefaultColor: '#fff'

},此物件定義了預設狀態下導航欄的狀態,和滑鼠懸浮時的一些狀態。

(5).var options = $.extend(defaults, options),擴充套件或者重寫defaults物件。

(6).return this.each(function() {

  var obj = $(this);

  var li_items = $("li", obj);

  $("li", obj).css('background-color', options.bgColor);

  li_items.mouseover(function(){

    $(this).animate({paddingTop: options.tagPaddingTop}, 300);

    $(this).css('background-color', options.bgMoverColor);

    $(this).css('color', options.textColor);

  }).mouseout(function() {

    $(this).animate({paddingTop: options.tagDefaultPaddingTop}, 500);

    $("li",$(this).parent()).css('background-color', options.bgColor);

    $("li",$(this).parent()).css('color', options.textDefaultColor);

  });

}),return 語句是為了保持鏈式呼叫。

this.each中的this是jquery物件例項。

var obj = $(this),轉換為jquery物件。

var li_items = $("li", obj),獲取obj下面所有的li元素集合。

$("li", obj).css('background-color', options.bgColor),設定li元素的背景色。

再下面的程式碼就是規定滑鼠懸浮和離開時li元素的相關樣式。

二.相關閱讀:

(1).$.fn.extend方法參閱$.extend()和$.fn.extend()一章節。

(2).each方法參閱jQuery each()一章節。

(3).鏈式呼叫參閱jQuery鏈式呼叫簡單例項程式碼一章節。

(4).mouseover事件參閱jQuery mouseover 事件一章節。

(5).mouseout事件參閱jQuery mouseout 事件一章節。

(6).animate參閱jQuery animate()一章節。

(7).parent參閱jQuery parent()一章節。

相關文章