CSS导航栏菜单制作大全

1.垂直导航栏

看代码:

<style type="text/css">
*{margin:0; padding:0; font-size:14px;}
a{color:#333;text-decoration:none}
.nav li a{ display:block; text-indent:20px; height:30px; line-height:30px; width:120px; background-color:#efefef; margin-bottom:1px;}
.nav li a:hover{ background-color:#F60; color:#fff}
</style>

<body>

<ul class="nav">
    <li><a href="#">首  页</a></li>
    <li><a href="#">关于我们</a></li>
    <li><a href="#">产品展示</a></li>
    <li><a href="#">售后服务</a></li>
    <li><a href="#">联系我们</a></li>
  </ul>

</body>

注意点:
1.display:block; text-indent:20px;,将a元素设置为块状元素,并内缩20px,如果用padding内缩会增加宽度。
2.<a href="#">首  页</a>,这句代码中的空格是全角输入法下的空格,半角下是这样的:
1 正确的效果:2

2.水平菜单栏

我们只需要将li标签浮动下,然后将a标签文本居中text-align:center;

*{margin:0; padding:0; font-size:14px;}
a{color:#333;text-decoration:none}
.nav li{float:left;}//
.nav li a{ display:block;text-align:center; height:30px; line-height:30px; width:120px; background-color:#efefef; margin-bottom:1px;}
.nav li a:hover{ background-color:#F60; color:#fff}

3

可以看到还有li标签的黑点,加一句.nav{list-style:none;}就好:

4

3.圆角菜单制作

需要一张图片背景:5,可以看到这张图片上下是一样的,所以我们给每个a标签设置其为背景,然后hover时将背景向下移动即可。background-position:0 -30px;

*{margin:0; padding:0; font-size:14px;}
a{color:#333;text-decoration:none}
.nav{list-style:none; height:30px; border-bottom:10px solid #F60; margin-top:20px; padding-left:50px;}
.nav li{float:left}
.nav li a{display:block; height:30px;text-align:center; line-height:30px; width:120px; background:url(images/btnBg.png); margin-left:1px;}
.nav li a.on, .nav li a:hover{ background-position:0 -30px; color:#fff;}

6

4.垂直伸缩菜单栏

效果:6

相对于上面的水平菜单2,我们增加几句代码:

.nav{list-style:none;margin-top:20px;}
.nav li a:hover{ background-color:#F60; color:#fff;height:40px;
    margin-top:-10px;}

把hover时的高度设为40px,同时要设margin向上移

5.水平菜单动画

7
当鼠标移上时增加宽度,并加上动画,我们用js代码实现:

<script text="text/javascript">
    window.onload=function(){
        var aA = document.getElementsByTagName("a");
        for(var i=0;i<aA.length;i++){
            //鼠标移上时
            aA[i].onmouseover=function(){
                clearInterval(this.time);//清除影响
                var This = this;
                This.time=setInterval(function(){
                    This.style.width=This.offsetWidth+8+"px";
                    if(This.offsetWidth>160){
                        clearInterval(This.time);
                    }
                },30);

            }
            //鼠标移出时
            aA[i].onmouseout=function(){
                clearInterval(this.time);//清除影响
                var This = this;
                This.time=setInterval(function(){
                    This.style.width=This.offsetWidth-8+"px";
                    if(This.offsetWidth<=120){
                        clearInterval(This.time);
                    }
                },30);
            }
        }
    }
</script>

当然,用jQuery更加简单:

<script type="text/javascript" src="jquery-1.2.6.min.js"></script>
<script text="text/javascript">
    $(function(){
        $("a").hover(
        function(){
            $(this).stop().animate({"width":"160"},200);
        },
        function(){
            $(this).stop().animate({"width":"120"},200);
        }
        );
    });
</script>

6.二级菜单制作

<style type="text/css">
* { margin: 0; padding: 0; font-size: 14px; }
a { color: #333; text-decoration: none }
ul{ list-style: none; }
.nav {height: 30px; border-bottom: 5px solid #F60; margin-left:50px; width:600px;}
.nav li { float: left; position:relative; height:30px; width:120px }
.nav li a { display: block; height: 30px; text-align: center; line-height: 30px; width:120px; background: #efefef; margin-left: 1px; }
.subNav{ position:absolute; top:30px; left:0; width:120px; height:0; overflow:hidden}
.subNav li a{ background:#ddd }
.subNav li a:hover{ background:#efefef}
</style>
<script>
window.onload=function(){
    var aLi=document.getElementsByTagName('li');
    for(var i=0; i<aLi.length; i++){
        aLi[i].onmouseover=function(){
            //鼠标经过一级菜单,二级菜单动画下拉显示出来
            var sub = this.getElementsByTagName('ul')[0];
            if(sub!=null){
                var This = sub;
                clearInterval(This.id);
                This.id=setInterval(function(){
                    This.style.height=This.offsetHeight+20+"px";
                    if(This.offsetHeight>=160){
                        clearInterval(This.id);
                    }
                },30);
            }
        }
        //鼠标离开菜单,二级菜单动画收缩起来。        
        aLi[i].onmouseout=function(){
             var sub = this.getElementsByTagName('ul')[0];
            if(sub!=null){
                var This = sub;
                clearInterval(This.id);
                This.id=setInterval(function(){
                    This.style.height=This.offsetHeight-20+"px";
                    if(This.offsetHeight<=0){
                        clearInterval(This.id);
                    }
                },30);
            }
        }


    }
}
</script>
</head>
<body>
<ul class="nav">
    <li><a href="#">一级菜单</a>
        <ul class="subNav">
            <li><a href="#">二级菜单</a></li>
            <li><a href="#">二级菜单</a></li>
            <li><a href="#">二级菜单</a></li>
            <li><a href="#">二级菜单</a></li>
        </ul>
    </li>
    <li><a href="#">一级菜单</a>
        <ul class="subNav">
            <li><a href="#">二级菜单</a></li>
            <li><a href="#">二级菜单</a></li>
            <li><a href="#">二级菜单</a></li>
            <li><a href="#">二级菜单</a></li>
        </ul>
    </li>
    <li><a href="#">一级菜单</a></li>
    <li><a href="#">一级菜单</a></li>
    <li><a href="#">一级菜单</a></li>
</ul>
</body>

8

  • 8
    点赞
  • 38
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值