Bootstrap tabbable和popover之间的冲突

时间:2012-07-05 11:25:11

标签: javascript jquery twitter-bootstrap popover

我正在尝试在同一页面中使用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>

3 个答案:

答案 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

http://getbootstrap.com/javascript/#popovers

答案 1 :(得分:1)

标签内容div的css属性overflow设置为auto(由Bootstrap提供)。这意味着当内容的大小超过div的大小时,浏览器会添加滚动条并剪切内容。您可以在自己的css文件中将属性覆盖为默认值(visible),或者只使用如下内联样式:

<div class="tab-content" style="overflow: visible;">

示例:http://jsfiddle.net/grc4/BXmC3/

答案 2 :(得分:-1)

而不是$ use jQuery它可以解决你的冲突。我认为你必须像这样增加标签内容的高度

.tab-content
{
    height:400px;
}