为了账号安全,请及时绑定邮箱和手机立即绑定

不管鼠标移动到哪一个一级菜单都是第一个二级菜单出现

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>动画菜单</title>
<style>
*{margin:0px;padding:0px;}
 ul{list-style:none;}
#topnav li{display:inline-block;width:100px;height:30px;line-height:30px;background:#999;margin:0px -2px;padding:0px;text-align:center;border-bottom:2px solid #455;}
.con ul{float:left;}
.con ul li{text-align:center;height:30px;background:#fef;margin:0px -3px;position:relative;top:-2px; width:100px;line-height:30px}
.hide {display:none}
.show {display:block }

</style>
</head>
<script>
window.onload=function(){
    var aul=document.getElementById("navcon");
    var atop=document.getElementById("topnav");
    var au=aul.getElementsByTagName('ul');
    var ali=atop.getElementsByTagName("li");
    for(var i=0;i<ali.length;i++){
        ali[i].index=i;
        ali[i].onmouseover=function(){
            this.style.backgroundColor="#fef"
            au[this.index].className=""
            
        }
        ali[i].onmouseout=function(){
            
        }
    }
}
   

</script>
</head>
<body>
<div id="wrap">
<ul id="topnav">
    <li>一级菜单</li>
    <li>一级菜单</li>
    <li>一级菜单</li>
    <li>一级菜单</li>
    <li>一级菜单</li>
</ul>
    <div class="con" id="navcon">
        <ul class="hide">
            <li>二级菜单</li>
            <li>二级菜单</li>
            <li>二级菜单</li>
            <li>二级菜单</li>
            <li>二级菜单</li>
        </ul>
        <ul class="hide">
            <li>二级菜单</li>
            <li>二级菜单</li>
            <li>二级菜单</li>
            <li>二级菜单</li>
            <li>二级菜单</li>
        </ul>
        <ul class="hide">
            <li>二级菜单</li>
            <li>二级菜单</li>
            <li>二级菜单</li>
            <li>二级菜单</li>
            <li>二级菜单</li>
        </ul>
        <ul class="hide">
            <li>二级菜单</li>
            <li>二级菜单</li>
            <li>二级菜单</li>
            <li>二级菜单</li>
            <li>二级菜单</li>
        </ul>
        <ul class="hide">
            <li>二级菜单</li>
            <li>二级菜单</li>
            <li>二级菜单</li>
            <li>二级菜单</li>
            <li>二级菜单</li>
        </ul>
        
    </div>
</div>
</body>
</html>

不管鼠标移动到哪一个一级菜单都是第一个二级菜单出现,这是怎么回事

正在回答

3 回答

uyfdtfyu
print(6)


0 回复 有任何疑惑可以回复我~

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

<title>动画菜单</title>

<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 oSubNav=this.getElementsByTagName('ul')[0];

            if(oSubNav){

            var This=oSubNav;

            clearInterval(This.time);

            This.time=setInterval(function(){

                    This.style.height=This.offsetHeight+16+"px";

                    if(This.offsetHeight>=120)

                    clearInterval(This.time);

                },30)

             }

          }

        //鼠标离开菜单,二级菜单动画收缩起来。    

aLi[i].onmouseout=function(){

            var oSubNav=this.getElementsByTagName('ul')[0];

            if(oSubNav){

            var This=oSubNav;

            clearInterval(This.time);

            This.time=setInterval(function(){

                    This.style.height=This.offsetHeight-16+"px";

                    if(This.offsetHeight<=0)

                    clearInterval(This.time);

                },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>

        <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>

        <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>

</ul>

</body>

</html>

0 回复 有任何疑惑可以回复我~

写的这是毛线啊


0 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消
导航条菜单的制作
  • 参与学习       123899    人
  • 解答问题       813    个

水平、垂直、圆角导航条菜单,让您的技术探索之路更高效

进入课程

不管鼠标移动到哪一个一级菜单都是第一个二级菜单出现

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信