请问为什么我这样写鼠标滑到二级菜单,他就给我缩回去了,不都是变量名吗?

<!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 This=this.getElementsByTagName('ul')[0];
        clearInterval(lala)
       var lala=setInterval(function(){
            This.style.height=This.offsetHeight+16+"px";
            if(This.offsetHeight>=120){
                clearInterval(lala);
            }
        },30)
		}
        //鼠标离开菜单,二级菜单动画收缩起来。		
		aLi[i].onmouseout=function(){     
	 var This=this.getElementsByTagName('ul')[0];
     clearInterval(lala)
        var lala=setInterval(function(){
            This.style.height=This.offsetHeight-16+"px";
            if(This.offsetHeight<=0){
                clearInterval(lala);
            }
        },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>

我这里面对  setInterval的变量写成lala 他就无法让我选二级菜单,

但是如果我这样写

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

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

     clearInterval(This.time)

        This.time=setInterval(function(){

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

            if(This.offsetHeight<=0){

                clearInterval(This.time);

            } },30) }}}

写成This.time就可以让鼠标在二级菜单上停留,而且不会缩回去,但是问题在于,This.time和lala一样不都只是一个变量吗?难道This.time有什么特殊含义?

慕仰6432972
浏览 1503回答 1
1回答

回夢

你要搞清楚对象和元素的区别。在this.time 里你的this是元素,等于在这个元素里面加上一个time可以理解为<ul time="setInterval()"></ul>而lala是一个var出来的变量这个变量装了setinterval这个定时器,可以理解为lala就是这个定时器本身。这能一样吗?如果你是从一个对象上扩展出来的time装入setinterval就不会出错。
打开App,查看更多内容
随时随地看视频慕课网APP