如何在悬停时制作 Bootstrap 的下拉菜单?

Posted

技术标签:

【中文标题】如何在悬停时制作 Bootstrap 的下拉菜单?【英文标题】:How to make Bootstrap's dropdown on hover? 【发布时间】:2012-10-25 23:52:30 【问题描述】:

如何使 twitter bootstrap 的菜单下拉菜单悬停而不是单击?

【问题讨论】:

您可以使用纯 css 简单地做到这一点,***.com/a/22365311/861607 【参考方案1】:

虽然How to make twitter bootstrap menu dropdown on hover rather than click 得到了很多人的支持,但使用较新版本的 Bootstrap,无需破解它。

http://cameronspear.com/blog/twitter-bootstrap-dropdown-on-hover-plugin/ 是现有 dropdown.js 的替代品,可让您在悬停时启用。无需修改 CSS。

【讨论】:

【参考方案2】:

这是我用来让导航栏下拉菜单在悬停时向下滑动而不只是弹出的功能

$('.navbar .dropdown').hover(function() 
  $(this).find('.dropdown-menu').first().stop(true, true).delay(250).slideDown();
, function() 
  $(this).find('.dropdown-menu').first().stop(true, true).delay(100).slideUp()
);

【讨论】:

【参考方案3】:

1.在鼠标悬停上隐藏下拉菜单

$(document).ready(function() 
    $('.nav li.dropdown').hover(function() 
        $(this).addClass('open');
    , function() 
        $(this).removeClass('open');
    );
);

2.在点击时隐藏下拉菜单

$(document).ready(function() 
    $('.nav li.dropdown').hover(function() 
        $(this).addClass('open');
    );
);

http://jsfiddle.net/7yMsQ/1/

【讨论】:

还在第二个(关闭)函数的第一行添加$('.nav li.dropdown').removeClass('open');,这样如果您有多个下拉菜单,它会隐藏其他可能打开的下拉菜单。【参考方案4】:

您只需使用 css 就可以做到这一点。在按钮下拉的情况下。

   <div class="btn-group btn-hover-group">
      <a href="#" id="selected" class="btn btn-default editor-submit">Action 1</a>
      <a href="#" class="btn btn-default dropdown-toggle"></a>
      <ul class="dropdown-menu pull-right">
        <li><a href="#" id="all" class="editor-submit">Action 2</a></li>
        <li><a href="#" id="matching" class="editor-submit">Action 3</a></li>
      </ul>
    </div>

&lt;a href="#" class="btn btn-default dropdown-toggle"&gt;&lt;/a&gt; 中删除了data-toggle="dropdown"

.btn-hover-group > a:hover ~ ul
 display:block;

.btn-hover-group > .dropdown-menu:hover
 display:block;

我希望这足以满足您的目的。

【讨论】:

【参考方案5】:

你可以像这样使用 bootstrap 4..

<div class="dropdown">
  <button class="dropbtn">Dropdown</button>
  <div class="dropdown-content">
    <a href="#">Link 1</a>
    <a href="#">Link 2</a>
    <a href="#">Link 3</a>
  </div>
</div>

然后定义下面的类属性值..它应该可以工作

.dropbtn 
    background-color: #4CAF50;
    color: white;
    padding: 16px;
    font-size: 16px;
    border: none;


.dropdown 
    position: relative;
    display: inline-block;


.dropdown-content 
    display: none;
    position: absolute;
    background-color: #f1f1f1;
    min-width: 160px;
    box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
    z-index: 1;


.dropdown-content a 
    color: black;
    padding: 12px 16px;
    text-decoration: none;
    display: block;

.dropdown:hover .dropdown-content display: block;

【讨论】:

以上是关于如何在悬停时制作 Bootstrap 的下拉菜单?的主要内容,如果未能解决你的问题,请参考以下文章

在悬停时制作 Twitter Bootstrap 菜单下拉菜单,而不是轻松点击(解决方案)

悬停时制作 React Bootstrap NavDropdown 下拉菜单

如何在 Bootstrap 4.1 中悬停时将子菜单下拉项向右移动?

Bootstrap 下拉菜单在悬停时关闭

Bootstrap下拉菜单在悬停时不下拉[重复]

Bootstrap 4.1中悬停时的下拉菜单