html - Firefox:将鼠标悬停在带有下拉菜单的按钮上会立即隐藏下拉菜单

标签 html css firefox

我有一个相当典型的下拉标记,主要区别在于容器是一个按钮而不是一个 div,这似乎是 Firefox 中问题的主要原因。该按钮内部包含一个列表,当我将鼠标悬停在该按钮上时,该列表显示正常。但是当我开始移动到下拉列表时,按钮上的悬停停用。如果我使用 DIV 元素而不是 BUTTON,那么它在两种浏览器中都可以正常工作。这是我正在使用的代码(plnkr:plnkr.co)

<!--Using 'button': does not work in Firefox-->
<button class="button">
   button text: this doesn't work in Firefox but works in Chrome
   <ul>
       <li>Item 1</li>
       <li>Item 2</li>
       ...
   </ul>
</button>

<!--Switching to 'div': works fine-->
<div class="button">
   switching to DIV: this works as expected
   <ul>
       <li>Item 1</li>
       <li>Item 2</li>
       ...
   </ul>
</div>    

相关 CSS:

.button {
  position: relative;
}

.button > ul {
  display: none;
  position: absolute;
}

.button:hover > ul {
  top: 100%;
  left: 0;
  display: block;
}

如果有人能帮我弄清楚为什么这种行为在 Chrome 和 Firefox 中不同,那就太好了。

最佳答案

我不推荐在按钮内使用 ul。因此,您可以做两件事来实现您的目标。

1 - 按钮后的列表:

<!-- HTML -->
<button class="button">Button</button>
<ul>
    <li>Item 1</li>
    <li>Item 2</li>
</ul>
<!-- CSS -->
button+ul {
    display: none;
}
button:hover+ul {
    display: block;
}

这有效( check demo ),但是您将无法将鼠标悬停在 ul 上(您可能想要)。

2 - 将其包裹在一个 div 中

<!-- HTML -->
<div class="buttonClass">
    <button>Button</button>
    <ul>
        <li>Item 1</li>
        <li>Item 2</li>
    </ul>
</div>
<!-- CSS -->
.buttonClass>ul {
    display: none;
}
.buttonClass:hover>ul {
    display: block;
}

这样(check demo),你可以将 ul 悬停

关于html - Firefox:将鼠标悬停在带有下拉菜单的按钮上会立即隐藏下拉菜单,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19309770/

相关文章:

php - HTML 表单不工作 - HTML <表单>

jquery - Bootstrap 3 的 Eonasdan DateTimePicker 不工作

带有 'yield' 关键字的 Javascript 生成器

html - 为什么带背景的 <a> 在 IE 中消失,但在 firefox 中没问题

javascript - 检测 NoScript(不是标签,扩展名)

html - 为什么 <img> 和 <p> 元素之间有既不是边距也不是填充的空间?

javascript - 悬停时打开 DIV,DIV 内容应从单独的 URL 动态加载

Css 技巧 - 如何对齐这个 div

javascript - Angular 重复指令语法

javascript - jQuery - 获取某些标签之间的所有 html