亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

請問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 關注
  • 1739 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號