请问cHeight和dHeight为什么放在外面就不行了,把这两段程序直接放进This.time=setInterval里就行

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

function  cHeight(){

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

            if(This.offsetHeight>=120){

                clearInterval(This.time); 

            }

}

            

function  dHeight(){

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

            if(This.offsetHeight<=0){

                clearInterval(This.time); 

            }

}

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("cHeight()",30)

        }

}

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

aLi[i].onmouseout=function(){

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

        if(oSubNav){

            var This=oSubNav;

            clearInterval(This.time);

        

        

        This.time=setInterval("dHeight()",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>

</html>


黄志明
浏览 1686回答 1
1回答

Caballarii

This的作用域的问题,你这样写This只能在onmouseover里面访问,外面无法访问,如果去掉var修饰而变成全局变量就可以了
打开App,查看更多内容
随时随地看视频慕课网APP