Check out the fiddle。我有一个基本的Bootstrap 3响应式导航,如下所示:
<div id="navbar" class="navbar navbar-fixed-top navbar-inverse">
<div class="container">
<a id="navbar-toggle" class="navbar-toggle" data-toggle="collapse" data-target=".nav-collapse">
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</a>
<a class="navbar-brand" href="#">Title Title Title</a>
<div id="nav-collapse" class="nav-collapse collapse">
<ul class="nav navbar-nav">
<li><a href="#option1">Option 1</a></li>
<li><a href="#option2">Option 2</a></li>
<li><a href="#option3">Option 3</a></li>
</ul>
</div>
</div>
</div>
导航项链接到页面上的部分,而不是不同的页面,因此我需要在下载时隐藏下拉列表。
每当我尝试使用jQuery手动切换下拉列表时,它会混淆下拉切换按钮的未来功能:
$("#navbar li a").click(function(event) {
// check if window is small enough so dropdown is created
$("#navbar-toggle").is(":visible")
$("#nav-collapse").toggle();
});
对此有更好的解决方法吗?
答案 0 :(得分:24)
如果你想在没有JavaScript的情况下这样做,你可以简单地将数据目标和数据切换添加到每个列表项,如下所示:
<li data-toggle="collapse" data-target=".nav-collapse"><a href="#option1">Option 1</a></li>
<li data-toggle="collapse" data-target=".nav-collapse"><a href="#option2">Option 2</a></li>
<li data-toggle="collapse" data-target=".nav-collapse"><a href="#option3">Option 3</a></li>
对于导航栏,当有切换按钮时,这实际上仅适用于移动视图模式。暴露导航栏时会发生奇怪的事情(切换按钮未显示)。
答案 1 :(得分:8)
改变这个:
$(document).ready(function () {
$("#navbar li a").click(function(event) {
// check if window is small enough so dropdown is created
$("#navbar-toggle").is(":visible")
$("#nav-collapse").toggle();
});
});
到此:
$(document).ready(function () {
$("#navbar li a").click(function(event) {
// check if window is small enough so dropdown is created
$("#nav-collapse").removeClass("in").addClass("collapse");
});
});
答案 2 :(得分:3)
我不知道为什么点击/点击折叠导航栏菜单下拉列表中的菜单项不会自动切换Bootstrap中的菜单。可能有更优雅的方法来做到这一点,但是,这是我修复它的方法(使用Bootstrap 3.0.3):
<li class="visible-xs">
<a href="#" data-toggle="collapse" data-target=".navbar-collapse">Link</a>
</li>
<li class="hidden-xs">
<a href="#">Link</a>
</li>
基本上,有两个版本的链接,每当显示菜单切换时(浏览器宽度<768px)将切换导航栏菜单,并且不会折叠它(浏览器宽度&gt; 768px)。如果你没有添加第二种类型,它会在尝试切换菜单时显示一个奇怪的幻影动画水平滚动条。
答案 3 :(得分:2)
我是Bootstrap的新手,但是对上面的代码进行了一些改动后,它现在可以很好地工作了。请记住,当您点击徽标时,下拉菜单也会关闭,这就是我为其添加了navbar-header的原因!
jQuery(document).ready(function () {
jQuery(".nav a, .navbar-header a").click(function(event) {
// check if window is small enough so dropdown is created
jQuery(".navbar-collapse").removeClass("in").addClass("collapse");
});
});
答案 4 :(得分:2)
使用Bootstrap 3.3.4我意识到我的旧方式已停止工作。将其更新为:
if ($('div.navbar-collapse').hasClass('in')) {
$('button.navbar-toggle:visible').click();
}
答案 5 :(得分:0)
如果需要在引导程序4上修复此问题,请尝试使用此jquery代码段。它以这种方式工作:如果扩展了navbar,则什么也不会发生(正常的引导行为)。如果导航栏折叠,则在单击事件后,将关闭导航栏。适用于bootstrap 4
$(".navbar a").click(function(event) {
// check if window is small enough so dropdown is created
var toggle = $(".navbar-toggler").is(":visible");
if (toggle) {
$(".navbar-collapse").collapse('hide');
}
});