我正在尝试制作一个带有标签的下拉菜单。问题是单击选项卡时关闭下拉列表。请参阅此演示:http://jsfiddle.net/timrpeterson/pv2Lc/2/。 (下面转载的代码)。
标签主播上的cited suggestion to stopPropagation()
似乎没有帮助。还有更好的方法吗?
<script src='http://netdna.bootstrapcdn.com/bootstrap/3.1.0/js/bootstrap.min.js'></script>
<link href='http://netdna.bootstrapcdn.com/bootstrap/3.1.0/css/bootstrap.min.css' rel="stylesheet" type="text/css"/>
<div class="dropdown">
<a id="dLabel" role="button" data-toggle="dropdown" data-target="#" href="/page.html">
Dropdown <span class="caret"></span>
</a>
<ul class="dropdown-menu" role="menu" aria-labelledby="dLabel">
<ul class="nav nav-tabs">
<li class="active"><a href="#home" data-toggle="tab">Home</a> </li>
<li><a href="#profile" data-toggle="tab">Profile</a></li>
<li><a href="#messages" data-toggle="tab">Messages</a></li>
</ul>
<!-- Tab panes -->
<div class="tab-content">
<div class="tab-pane active" id="home">HOME asdfasdfsda</div>
<div class="tab-pane" id="profile">PROFILE asdfafas</div>
<div class="tab-pane" id="messages">MESSAGES asdfdas</div>
</div>
</ul>
</div>
答案 0 :(得分:11)
引用的建议不起作用,因为应在实际标签(即链接)上调用.tab('show')
方法,而不是选项卡窗格。
所以代码应该是:
$('.dropdown-menu a[data-toggle="tab"]').click(function (e) {
e.stopPropagation()
$(this).tab('show')
})
这是一个更新的小提琴:http://jsfiddle.net/pv2Lc/6/
答案 1 :(得分:5)
使用特定的引导事件:hide.bs.dropdown
(在下拉列表即将关闭时触发)允许您通过调用e.preventDefault()
取消“隐藏”操作。 (doc here,scrolldown
组件的特定引导事件列表)
您可以在用户点击标签时激活特殊标记,并在下拉列表中的hide.bs.dropdown
事件中检查该标记:
$('#myTabs').on('click', '.nav-tabs a', function(){
// set a special class on the '.dropdown' element
$(this).closest('.dropdown').addClass('dontClose');
})
$('#myDropDown').on('hide.bs.dropdown', function(e) {
if ( $(this).hasClass('dontClose') ){
e.preventDefault();
}
$(this).removeClass('dontClose');
});
fiddle
(我在你的例子中添加了html id,根据你的需要更改选择器)