同时运行多个setIntervals的问题

时间:2010-05-14 03:05:51

标签: javascript dhtml menubar setinterval

我在这里的第一篇文章。我想制作一个水平菜单,子菜单在鼠标悬停时向下滑动。我知道我可以使用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.

我一直在寻找几个小时,但我完全陷入困境。

提前致谢。

2 个答案:

答案 0 :(得分:7)

我的第一个建议是

  1. 正确使用分号而不依赖分号插入
  2. 不要将函数作为字符串传递(需要隐式eval
  3. use JavaScript to attach events in a non-obtrusive manner
  4. var up   = [],
        down = [],
        submenustart;
    
    function titleover(headmenu, inter) {
        up[inter]   = window.clearInterval(up[inter]);
        down[inter] = window.setInterval(function() { slidedown(headmenu.lastChild); }, 1);
    }
    
    function slidedown(submenu) {
        if ( submenu.offsetTop < submenustart  ) {
            submenu.style.top = submenu.offsetTop + 1 + "px";
        }
    }
    
    function titleout(headmenu, inter) {
        down[inter] = window.clearInterval(down[inter]);
        up[inter]   = window.setInterval(function() { slideup(headmenu.lastChild); }, 1);
    }
    
    function slideup(submenu) {
        if ( submenu.offsetTop > submenustart - submenu.clientHeight + 1 ) {
            submenu.style.top = submenu.offsetTop - 1 + "px";
        }
    }
    

    我的第二个建议是不要将表用于菜单,因为它们不是表格数据。而是使用未排序的列表。

    <ul class="hoofding" id="hoofding">
        <li onmouseover="titleover(this, 0)" onmouseout="titleout(this, 0)">
            <a href="#" class="hoofdinglink" id="hoofd1">AAAA</a>
            <ul class="menu">
                <li><a href="...">1111</a></li>
                <li><a href="...">2222</a></li>
                <li><a href="...">3333</a></li>
            </ul>
        </li>
        <li onmouseover="titleover(this, 1)" onmouseout="titleout(this, 1)">
            <a href="#" class="hoofdinglink">BBBB</a>
            <ul class="menu">
                <li><a href="...">1111</a></li>
                <li><a href="...">2222</a></li>
                <li><a href="...">3333</a></li>
            </ul>
        </li>
    </ul>
    

答案 1 :(得分:0)

AFAIK,(并根据Gecko DOM参考)window.clearInterval()不会返回任何内容,这可能是弄乱事情的原因。