jQuery 打造動態(tài)下滑菜單實現(xiàn)說明
更新時間:2010年04月15日 22:03:38 作者:
本教程將分步講解如何使用JQuery和CSS打造一個炫酷動感菜單。
jQuery的"write less, do more"的特性可謂是家喻戶曉,即使沒有很豐富JS編程經(jīng)驗的人,也可以通過其提供的API很快學(xué)會如何使用,當然,如果您經(jīng)驗豐富,我還是建議您可以理解jQuery各主要函數(shù)的實現(xiàn)原理,其他不說了,直接看看如何用它來實現(xiàn)菜單神奇的效果吧。

Step1 - HTML結(jié)構(gòu)
看一下菜單的HTML代碼,跟平常的菜單代碼沒有什么區(qū)別:
<div id="menu" class="menu">
<ul>
<li><a href="javascript:;">Home</a></li>
<li><a href="javascript:;">HTML/CSS</a></li>
<li><a href="javascript:;">JavaScript</a></li>
<li><a href="javascript:;">Resources</a></li>
<li><a href="javascript:;">Tutorials</a></li>
<li><a href="javascript:;">About</a></li>
</ul>
</div>
關(guān)鍵在于利用腳本在每個錨點(a元素)中建立幾個分隔層,這樣就可以在鼠標懸停時分別控制它們產(chǎn)生動畫。為此,我們要在DOM加載完成時候修改DOM的結(jié)構(gòu),使得每個錨點代碼變成如下:
<a href="javascript:;">
<span class="out">Home</span>
<span class="bg"></span>
<span class="over">Home</span>
</a>
原先的每個錨點中的內(nèi)容會被附加到兩個span元素(.out和.over)里面,另外一個span元素(.bg)為背景圖片層。
至于如何修改DOM結(jié)構(gòu),JS代碼將在Step3中講解。
Step2 - CSS樣式
在示例中,展示了兩種樣式,有使用背景圖的和沒有使用背景圖的(具體查看演示),您也可以自由定制自己的樣式,以設(shè)計出更炫酷的菜單,這里提供基本的樣式和解釋:
/* 以下是菜單基本的樣式 */
.menu ul li {
float: left;
/* 菜單子元素的內(nèi)容超出不可見 */
overflow: hidden;
/* 以下省略部分代碼 */
}
.menu ul li a {
/* 必須是相對定位 */
position: relative;
display: block;
width: 110px;
/* 以下省略部分代碼 */
}
.menu ul li a span {
/* 所有層將使用絕對定位 */
position: absolute;
left: 0;
width: 110px;
}
.menu ul li a span.out {
top: 0px;
}
.menu ul li a span.over,
.menu ul li a span.bg {
/* 起初.over層和.bg層相對a元素-45px以達到隱藏的效果 */
top: -45px;
}
/* 以下是使用背景圖的示例 */
#menu {
/* 菜單背景 */
background:url(bg_menu.gif) scroll 0 -1px repeat-x;
border:1px solid #CCC;
}
#menu ul li a {
color: #000;
}
#menu ul li a span.over {
color: #FFF;
}
#menu ul li span.bg {
/* 指定高度和背景圖 */
height: 45px;
background: url(bg_over.gif) center center no-repeat;
}
您也可以在自行定制CSS樣式,這里還提供了簡化版的樣式(查看演示)
Step3 - JavaScript代碼
首先要做的是,實現(xiàn)Step1中所說的,在DOM加載完成后修改其DOM結(jié)構(gòu),具體做法如下:
// 把每個a中的內(nèi)容包含到一個層(span.out)中,
// 然后再在span.out層后面追加背景圖層(span.bg)
$("#menu li a").wrapInner( '<span class="out"></span>' )
.append( '<span class="bg"></span>' );
// 循環(huán)為菜單的a每個添加一個層(span.over)
$("#menu li a").each(function() {
$( '<span class="over">' + $(this).text() + '</span>' )
.appendTo( this );
});
在講動畫代碼之前,先看一下動畫的過程,如下圖所示:

在Step1中我們知道DOM加載后,a元素中建立了幾個分隔層,在Step2中,CSS樣式中,我們設(shè)置了span.bg和span.over層的top屬性為-45px,因為span元素已設(shè)置為絕對定位,它將相對于li a 元素向上-45px,因為li元素內(nèi)容超出不可見,所以開始時,.bg層和.over層位于空間范圍外。
我們要設(shè)置的動畫過程是,當鼠標懸停時,三個層同時向下移動,span.out層向下移動至移除可見范圍,span.over和span.bg移動進入可見區(qū)域,設(shè)置span.bg速度比span.over速度稍快,錯位產(chǎn)生更加效果。
要實現(xiàn)這樣動畫效果,使用jQuery的.animate()方法很容易就可以實現(xiàn),以下是JS代碼和解釋:
$("#menu li a").hover(function() {
// 鼠標懸停時候被觸發(fā)的函數(shù)
$(".out",this).stop().animate({'top':'45px'},250);//下滑至隱藏
$(".over",this).stop().animate({'top':'0px'},250); //下滑至顯示
$(".bg",this).stop().animate({'top':'0px'},120); //下滑至顯示
}, function() {
// 鼠標移出時候被觸發(fā)的函數(shù)
$(".out",this).stop().animate({'top':'0px'},250); //上滑至顯示
$(".over",this).stop().animate({'top':'-45px'},250);//上滑至隱藏
$(".bg",this).stop().animate({'top':'-45px'},120);//上滑至隱藏
});
總結(jié)
以上講解了如何一步步打造jQuery動態(tài)下滑菜單,您可以按部就班自己實現(xiàn)一個,也可以下載源代碼修改定制,當然,您有什么好的提議或者有什么問題,都可以給我留言。
查看最終效果
jOuery 動態(tài)下滑菜單打包下載
PS:本文由維奇總結(jié)

Step1 - HTML結(jié)構(gòu)
看一下菜單的HTML代碼,跟平常的菜單代碼沒有什么區(qū)別:
復(fù)制代碼 代碼如下:
<div id="menu" class="menu">
<ul>
<li><a href="javascript:;">Home</a></li>
<li><a href="javascript:;">HTML/CSS</a></li>
<li><a href="javascript:;">JavaScript</a></li>
<li><a href="javascript:;">Resources</a></li>
<li><a href="javascript:;">Tutorials</a></li>
<li><a href="javascript:;">About</a></li>
</ul>
</div>
關(guān)鍵在于利用腳本在每個錨點(a元素)中建立幾個分隔層,這樣就可以在鼠標懸停時分別控制它們產(chǎn)生動畫。為此,我們要在DOM加載完成時候修改DOM的結(jié)構(gòu),使得每個錨點代碼變成如下:
復(fù)制代碼 代碼如下:
<a href="javascript:;">
<span class="out">Home</span>
<span class="bg"></span>
<span class="over">Home</span>
</a>
原先的每個錨點中的內(nèi)容會被附加到兩個span元素(.out和.over)里面,另外一個span元素(.bg)為背景圖片層。
至于如何修改DOM結(jié)構(gòu),JS代碼將在Step3中講解。
Step2 - CSS樣式
在示例中,展示了兩種樣式,有使用背景圖的和沒有使用背景圖的(具體查看演示),您也可以自由定制自己的樣式,以設(shè)計出更炫酷的菜單,這里提供基本的樣式和解釋:
復(fù)制代碼 代碼如下:
/* 以下是菜單基本的樣式 */
.menu ul li {
float: left;
/* 菜單子元素的內(nèi)容超出不可見 */
overflow: hidden;
/* 以下省略部分代碼 */
}
.menu ul li a {
/* 必須是相對定位 */
position: relative;
display: block;
width: 110px;
/* 以下省略部分代碼 */
}
.menu ul li a span {
/* 所有層將使用絕對定位 */
position: absolute;
left: 0;
width: 110px;
}
.menu ul li a span.out {
top: 0px;
}
.menu ul li a span.over,
.menu ul li a span.bg {
/* 起初.over層和.bg層相對a元素-45px以達到隱藏的效果 */
top: -45px;
}
/* 以下是使用背景圖的示例 */
#menu {
/* 菜單背景 */
background:url(bg_menu.gif) scroll 0 -1px repeat-x;
border:1px solid #CCC;
}
#menu ul li a {
color: #000;
}
#menu ul li a span.over {
color: #FFF;
}
#menu ul li span.bg {
/* 指定高度和背景圖 */
height: 45px;
background: url(bg_over.gif) center center no-repeat;
}
您也可以在自行定制CSS樣式,這里還提供了簡化版的樣式(查看演示)
Step3 - JavaScript代碼
首先要做的是,實現(xiàn)Step1中所說的,在DOM加載完成后修改其DOM結(jié)構(gòu),具體做法如下:
復(fù)制代碼 代碼如下:
// 把每個a中的內(nèi)容包含到一個層(span.out)中,
// 然后再在span.out層后面追加背景圖層(span.bg)
$("#menu li a").wrapInner( '<span class="out"></span>' )
.append( '<span class="bg"></span>' );
// 循環(huán)為菜單的a每個添加一個層(span.over)
$("#menu li a").each(function() {
$( '<span class="over">' + $(this).text() + '</span>' )
.appendTo( this );
});
在講動畫代碼之前,先看一下動畫的過程,如下圖所示:

在Step1中我們知道DOM加載后,a元素中建立了幾個分隔層,在Step2中,CSS樣式中,我們設(shè)置了span.bg和span.over層的top屬性為-45px,因為span元素已設(shè)置為絕對定位,它將相對于li a 元素向上-45px,因為li元素內(nèi)容超出不可見,所以開始時,.bg層和.over層位于空間范圍外。
我們要設(shè)置的動畫過程是,當鼠標懸停時,三個層同時向下移動,span.out層向下移動至移除可見范圍,span.over和span.bg移動進入可見區(qū)域,設(shè)置span.bg速度比span.over速度稍快,錯位產(chǎn)生更加效果。
要實現(xiàn)這樣動畫效果,使用jQuery的.animate()方法很容易就可以實現(xiàn),以下是JS代碼和解釋:
復(fù)制代碼 代碼如下:
$("#menu li a").hover(function() {
// 鼠標懸停時候被觸發(fā)的函數(shù)
$(".out",this).stop().animate({'top':'45px'},250);//下滑至隱藏
$(".over",this).stop().animate({'top':'0px'},250); //下滑至顯示
$(".bg",this).stop().animate({'top':'0px'},120); //下滑至顯示
}, function() {
// 鼠標移出時候被觸發(fā)的函數(shù)
$(".out",this).stop().animate({'top':'0px'},250); //上滑至顯示
$(".over",this).stop().animate({'top':'-45px'},250);//上滑至隱藏
$(".bg",this).stop().animate({'top':'-45px'},120);//上滑至隱藏
});
總結(jié)
以上講解了如何一步步打造jQuery動態(tài)下滑菜單,您可以按部就班自己實現(xiàn)一個,也可以下載源代碼修改定制,當然,您有什么好的提議或者有什么問題,都可以給我留言。
查看最終效果
jOuery 動態(tài)下滑菜單打包下載
PS:本文由維奇總結(jié)
您可能感興趣的文章:
- jquery實現(xiàn)動態(tài)菜單的實例代碼
- jquery插件之easing 動態(tài)菜單
- jquery實現(xiàn)可橫向和豎向展開的動態(tài)下滑菜單效果
- jQuery實現(xiàn)的背景動態(tài)變化導(dǎo)航菜單效果
- jQuery實現(xiàn)的動態(tài)伸縮導(dǎo)航菜單實例
- jQuery實現(xiàn)可用于博客的動態(tài)滑動菜單
- jquery實現(xiàn)鼠標經(jīng)過顯示下劃線的漸變下拉菜單效果代碼
- jquery實現(xiàn)鼠標滑過顯示二級下拉菜單效果
- jQuery實現(xiàn)響應(yīng)鼠標背景變化的動態(tài)菜單效果代碼
相關(guān)文章
jquery仿京東導(dǎo)航/仿淘寶商城左側(cè)分類導(dǎo)航下拉菜單效果
jquery實現(xiàn)下拉菜單效果,jquery寫的仿京東導(dǎo)航菜單,一個經(jīng)典的左側(cè)多級導(dǎo)航菜單,學(xué)會了可以任意改變布局,感興趣的朋友可以參考下哈,希望對你有所幫助2013-04-04
jQuery學(xué)習(xí)筆記 更改jQuery對象
jQuery提供了一些方法,使流程變?yōu)樯蒵Query對象A,操作jQuery對象A;更改為jQuery對象B,操作jQuery對象B2012-09-09
jQuery.fn和jQuery.prototype區(qū)別介紹
jQuery.fn和jQuery.prototype想必大家對它并不陌生吧,那么你們知道它們之間的區(qū)別嗎?在本文有個不錯的示例大家可以參考下2013-10-10
jQuery插件echarts去掉垂直網(wǎng)格線用法示例
這篇文章主要介紹了jQuery插件echarts去掉垂直網(wǎng)格線用法,結(jié)合實例形式對比分析了jQuery圖標插件echarts針對垂直網(wǎng)格線的相關(guān)設(shè)置操作技巧,需要的朋友可以參考下2017-03-03

