我正在尝试在同一页面中使用Twitter Bootstrap tabbable和Bootstrap popovers。我难以解决弹出窗口问题,这些弹出窗口不能超出标签的限制(问题是当弹出窗口出现在边框旁边时,它是半隐藏的)。
我不是JQuery的专家,但就我所知,问题来自于在“iframe”中创建的标签,并且弹出框不能显示在其“iframe”之外。
有什么方法可以解决这个问题吗? (=即使靠近标签的边框,也能正确显示弹出窗口?)
非常感谢!
以下是显示我的问题的示例代码(准备复制/粘贴.html http://jsfiddle.net/7PU2D/):
<!DOCTYPE html>
<head>
<link href="http://twitter.github.com/bootstrap/assets/css/bootstrap.css" rel="stylesheet">
<link href="http://twitter.github.com/bootstrap/assets/css/bootstrap-responsive.css" rel="stylesheet">
</head>
<body>
<div class="span2">
Left column
</div>
<div class="span6">
<div class="tabbable">
<ul class="nav nav-tabs">
<li class="active"><a href="#tab1" data-toggle="tab">tab1</a></li>
<li><a href="#tab2" data-toggle="tab">tab2</a></li>
<li><a href="#tab3" data-toggle="tab">tab3</a></li>
</ul>
<div class="tab-content">
<div id="tab1" class="tab-pane active">tab1 text
<div class="well">
<a href="#" class="btn btn-danger" rel="popover" style="position: relative;" data-content="And here's some amazing content. It's very engaging. right? " data-original-title="A Title">hover for popover</a>
</div>
</div>
<div id="tab2" class="tab-pane">tab2 text</div>
<div id="tab3" class="tab-pane">tab3 taxt</div>
</div>
</div>
</div>
<script src="http://twitter.github.com/bootstrap/assets/js/jquery.js"></script>
<script src="http://twitter.github.com/bootstrap/assets/js/bootstrap.js"></script>
<script>
$(function(){
$('a[rel=popover]').popover({
trigger: 'hover',
placement: 'in bottom',
animate: true,
delay: 500,
});
});
</script>
</body>
答案 0 :(得分:4)
使用“容器”选项。这样你就可以将popover / tip添加到body元素中,它不会被标签窗格溢出:overflow:hidden ...例如:
<script>
$(function(){
$('a[rel=popover]').popover({
trigger: 'hover',
placement: 'in bottom',
animate: true,
delay: 500,
container: 'body'
});
});
</script>
或:
<a rel="popover" data-container="body">Pop Me Open</a>
您的工具提示仍会正确放置在您的链接旁边,但由于它现在已附加到正文标记,因此它不会被标签窗格“半隐藏”。
在bootstrap网站上查看工具提示/ popover的文档...
2.3.2:
http://getbootstrap.com/2.3.2/javascript.html#popovers
或3.0
答案 1 :(得分:1)
标签内容div的css属性overflow
设置为auto
(由Bootstrap提供)。这意味着当内容的大小超过div的大小时,浏览器会添加滚动条并剪切内容。您可以在自己的css文件中将属性覆盖为默认值(visible
),或者只使用如下内联样式:
<div class="tab-content" style="overflow: visible;">
答案 2 :(得分:-1)
而不是$ use jQuery它可以解决你的冲突。我认为你必须像这样增加标签内容的高度
.tab-content
{
height:400px;
}