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

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

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

慕仰6432972 2016-07-23 12:07:26
<!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有什么特殊含义?
查看完整描述

1 回答

已采纳
?
回夢

TA贡献18条经验 获得超5个赞

你要搞清楚对象和元素的区别。

在this.time 里你的this是元素,等于在这个元素里面加上一个time

可以理解为<ul time="setInterval()"></ul>

而lala是一个var出来的变量

这个变量装了setinterval这个定时器,可以理解为lala就是这个定时器本身。

这能一样吗?

如果你是从一个对象上扩展出来的time装入setinterval就不会出错。

查看完整回答
反对 回复 2016-07-28
  • 1 回答
  • 0 关注
  • 1502 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信