1

这个问题是我之前提出的问题的后续问题(有不同的转折):

我不确定如何恰当地描述我的问题:这是一个错误,只需要调试。

这是我的 jsFiddle:http: //jsfiddle.net/Wagtail/b6Juh/18/

我需要能够滚动项目 A、项目 B 和项目 C,而不是在鼠标离开项目 A 时完全消失。为什么会发生这种情况?

为了方便起见,这里复制了 JavaScript、HTML 和 CSS 代码:

HTML

<table id="headMenu">
    <tr>
        <td id="head1">Item 1</td>
        <td id="head2">Item 2</td>
        <td id="head3">Item 3</td>
    </tr>
</table>
<table id="subMenu">
    <tr>
        <td>Dynamic Content!</td>
    </tr>
</table>​

CSS 代码:

#headMenu{background:rgb(142,180,227);width:90%;height:50px;color:white;font-weight:bold;text-align:center;margin:20px 5%  0px 5%%;vertical-align:middle;}
#subMenu{background:rgb(195,214,155);width:90%;height:50px;color:white;font-weight:bold;text-align:center;margin:1px 5% auto 5%;vertical-align:middle;}
#headMenu td:hover{background:rgb(162,200,240);}
#subMenu td:hover{background:rgb(210,230,170);}​

JavaScript 代码:

var a = 500, head1 = document.getElementById('head1'), subMenu = document.getElementById('subMenu'), timeout;

head1.onmouseover = function(displayMenu) {
    subMenu.innerHTML = '<tr><td>Item A</td><td>Item B</td><td>Item C</td></tr>';
    head1.onmouseout = function(getScroll) {
        subMenu.onmouseover = function(breakTimeout) {
            clearTimeout(timeout);
            subMenu.onmouseout = function(endFunction) {
                subMenu.innerHTML = '<tr><td>Dynamic Content!</td></tr>';
            };
        };
        timeout = setTimeout(function() {
            document.getElementById("subMenu").innerHTML = '<tr><td>Dynamic Content!</td></tr>';
        }, a);
    };
};

提前感谢任何答案!如果您需要澄清,我很乐意回复。

4

1 回答 1

1

当鼠标从一个子菜单表格单元格移动到另一个时,将触发您的 subMenu.onmouseout 函数。解决此问题的一种简单方法是添加另一个超时以在单元格之间移动。

我已经更新了您的 jsfiddle 示例以说明我的意思:

http://jsfiddle.net/b6Juh/22/

于 2012-06-08T16:31:26.693 回答