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

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

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

黄志明 2016-04-08 14:40:46
<!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>
查看完整描述

1 回答

已采纳
?
Caballarii

TA贡献1123条经验 获得超629个赞

This的作用域的问题,你这样写This只能在onmouseover里面访问,外面无法访问,如果去掉var修饰而变成全局变量就可以了

查看完整回答
反对 回复 2016-04-08
  • 黄志明
    黄志明
    非常感谢,你的解答又帮了大忙了!但是这样会出现一个BUG,就是当鼠标从第一个标签移动第二个标签上时,动态效果就停止了。
  • 1 回答
  • 0 关注
  • 1685 浏览
慕课专栏
更多

添加回答

举报

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