0

我正在制作一个使用 JavaScript 显示和隐藏的简单下拉菜单。菜单显示,链接仍然有效,但是当我将鼠标悬停在第一个下拉链接上时,即使我为它设置了特定的高度,整个下拉菜单也会消失。我还有一个单独的 div,其下方有内容,并且该 div 中的文本被推开,尽管我认为 z-index 会解决这个问题。

function showDrop() {
  document.getElementById("dropdown").style.visibility = "visible";
}

function hideDrop() {
  document.getElementById("dropdown").style.visibility = "hidden";
}
#nav {
  /* margin-left: 550px;
  padding-top: 110px; */
  font-family: 'Averia Serif Libre', cursive;
  font-size: 24px;
  position: relative;
}

#nav ul li {
  display: block;
  float: left;
  margin-right: 10px;
}

#nav ul li a:link,
#nav ul li a:visited {
  text-decoration: none;
  float: left;
}

#nav ul li a:hover,
#nav ul li a:active {
  color: #00B2EE;
}

#nav ul li ul {
  visibility: hidden;
  top: 0;
  left: 0;
  display: block;
  width: 100px;
  height: 100px;
  clear: both;
  z-index: 2;
  padding-top: 2px;
}

#nav ul li ul li {
  width: 100px;
  z-index: inherit;
  background-color: #AAA;
  font-size: 16px;
  line-height: 22px;
}
<div id="nav">
  <ul>
    <li><a href="#" id="nAbout">About</a></li>
    <li><a href="#" id="nPortfolio" onMouseOver="showDrop();">Portfolio</a>
      <ul id="dropdown" onMouseOut="hideDrop();">
        <li><a href="#">Print Design</a></li>
        <li><a href="#">Web Design</a></li>
        <li><a href="#">Illustration</a></li>
      </ul>
    </li>
    <li><a href="#" id="nContact">Contact</a></li>
    <li><a href="#" id="nBlog">Blog</a></li>
  </ul>
</div>

4

1 回答 1

0

请改用该onmouseleave事件,因为onmouseout即使您悬停在元素的子元素上,鼠标也会“退出”。示例代码:

$("#dropdown").mouseleave(function() { //jQuery required; onmouseleave is IE-specific
    hideDrop();
});

希望有帮助。

于 2012-08-14T19:41:22.353 回答