【发布时间】:2010-05-14 03:05:51
【问题描述】:
我在这里的第一篇文章。我想制作一个水平菜单,子菜单在鼠标悬停时向下滑动。我知道我可以使用 jQuery,但这是为了练习我的 javascript 技能。
我使用以下代码:
var up = new Array()
var down = new Array()
var submenustart
function titleover(headmenu, inter)
{
submenu = headmenu.lastChild
up[inter] = window.clearInterval(up[inter])
down[inter] = window.setInterval("slidedown(submenu)",1)
}
function slidedown(submenu)
{
if(submenu.offsetTop < submenustart)
{
submenu.style.top = submenu.offsetTop + 1 + "px"
}
}
function titleout(headmenu, inter)
{
submenu = headmenu.lastChild
down[inter] = window.clearInterval(down[inter])
up[inter] = window.setInterval("slideup(submenu)", 1)
}
function slideup(submenu)
{
if(submenu.offsetTop > submenustart - submenu.clientHeight + 1)
{
submenu.style.top = submenu.offsetTop - 1 + "px"
}
}
变量 submenustart 在另一个函数中被指定了一个与我的问题无关的值。
HTML 看起来像这样:
<table class="hoofding" id="hoofding">
<tr>
<td onmouseover="titleover(this, 0)" onmouseout="titleout(this, 0)"><a href="#" class="hoofdinglink" id="hoofd1">AAAA</a>
<table class="menu">
<tr><td><a href="...">1111</a></td></tr>
<tr><td><a href="...">2222</a></td></tr>
<tr><td><a href="...">3333</a></td></tr>
</table></td>
<td onmouseover="titleover(this, 1)" onmouseout="titleout(this, 1)"><a href="#" class="hoofdinglink">BBBB</a>
<table class="menu">
<tr><td><a href="...">1111</a></td></tr>
<tr><td><a href="...">2222</a></td></tr>
<tr><td><a href="...">3333</a></td></tr>
<tr><td><a href="...">4444</a></td></tr>
<tr><td><a href="...">5555</a></td></tr>
</table></td>
...
</tr>
</table>
会发生以下情况:
如果我反复(例如)菜单A,它可以正常工作。
如果我现在转到菜单 B,则应用于 A 的间隔现在应用于 B。现在有 2 个间隔函数应用于 B。最初用于 A 的一个函数和一个由鼠标悬停在 B 上触发的新函数。
如果我要去 A,那么所有的间隔现在都适用于 A。
我一直在寻找几个小时,但我完全陷入困境。
提前致谢。
【问题讨论】:
-
完成动画后不要忘记致电
clearInterval。 -
感谢您的评论,但我知道这一点。我后来确实添加了这个 clearInterval。
标签: javascript dhtml menubar setinterval