2009. 06. 3

动感下拉菜单-Jquery&CSS

    一个好的导航应该在第一次访问网站的时候最大限度地引导用户的视线,所以制作一个排列有序、直观的导航是非常重要的,如果能给那些需要下拉的菜单加上优美的下拉效果会给导航条加分不少,下面的教程将会教大家如何制作一个优美的、动感的下拉菜单。

    本教程原文:Sexy Drop Down Menu w/ jQuery & CSS,由jsssc.cn翻译。

 

查看DEMO

 

 

image1

第一步:HTML

第一级li为一级菜单,第二级li为子菜单。


第二步:CSS

ul.topnav {
    list-style: none;
    padding: 0 20px;
    margin: 0;
    float: left;
    width: 920px;
    background: #222;
    font-size: 1.2em;
    background: url(topnav_bg.gif) repeat-x;
}
ul.topnav li {
    float: left;
    margin: 0;
    padding: 0 15px 0 0;
    position: relative; /*--Declare X and Y axis base for sub navigation--*/
}
ul.topnav li a{
    padding: 10px 5px;
    color: #fff;
    display: block;
    text-decoration: none;
    float: left;
}
ul.topnav li a:hover{
    background: url(topnav_hover.gif) no-repeat center top;
}
ul.topnav li span { /*--Drop down trigger styles--*/
    width: 17px;
    height: 35px;
    float: left;
    background: url(subnav_btn.gif) no-repeat center top;
}
ul.topnav li span.subhover {background-position: center bottombottom; cursor: pointer;} /*--Hover effect for trigger--*/
ul.topnav li ul.subnav {
    list-style: none;
    position: absolute; /*--Important - Keeps subnav from affecting main navigation flow--*/
    left: 0; top: 35px;
    background: #333;
    margin: 0; padding: 0;
    display: none;
    float: left;
    width: 170px;
    border: 1px solid #111;
}
ul.topnav li ul.subnav li{
    margin: 0; padding: 0;
    border-top: 1px solid #252525; /*--Create bevel effect--*/
    border-bottom: 1px solid #444; /*--Create bevel effect--*/
    clear: both;
    width: 170px;
}
html ul.topnav li ul.subnav li a {
    float: left;
    width: 145px;
    background: #333 url(dropdown_linkbg.gif) no-repeat 10px center;
    padding-left: 20px;
}
html ul.topnav li ul.subnav li a:hover { /*--Hover effect for subnav links--*/
    background: #222 url(dropdown_linkbg.gif) no-repeat 10px center;
}

第三步:Juqery

$(document).ready(function(){   

    $("ul.subnav").parent().append(""); //Only shows drop down trigger when js is enabled (Adds empty span tag after ul.subnav*)   

    $("ul.topnav li span").click(function() { //When trigger is clicked...   

        //Following events are applied to the subnav itself (moving subnav up and down)
        $(this).parent().find("ul.subnav").slideDown('fast').show(); //Drop down the subnav on click   

        $(this).parent().hover(function() {
        }, function(){
            $(this).parent().find("ul.subnav").slideUp('slow'); //When the mouse hovers out of the subnav, move it back up
        });   

        //Following events are applied to the trigger (Hover events for the trigger)
        }).hover(function() {
            $(this).addClass("subhover"); //On hover over, add class "subhover"
        }, function(){  //On Hover Out
            $(this).removeClass("subhover"); //On hover out, remove class "subhover"
    });   

});

 

degrade_gracefully_demo

 

脚本被禁用时你将看到的是:

 

javascript_disabled

 查看DEMO

     你可以修改部分的代码来满足自己的需要,如果有什么好的建议可以联系作者:Soh Tanaka

 

    本站所有文章,除特别标明外,皆为原创。如需转载,请保留本说明文字并以链接的形式保留本文链接和出处:

   转载自:动感下拉菜单-Jquery&CSS | 路可

 

 

Related posts:

  1. 纯CSS鱼眼菜单
  2. 用jQuery实现各种CSS3效果
  3. 24个jQuery驱动的网站
  4. jQuery日常使用技巧总结
  5. 10个最常用的CSS className

Leave a Reply