我在bootstrap面板标题部分中有很少的控件,我希望它们显示在右侧。我使用" pull-right" css类将右侧的控件对齐,但是面板标题正在失去它的高度。在IE8及更高版本以及chrome中都会出现此行为。
当前状态:
Fiddler: https://jsfiddle.net/99x50s2s/156/
代码:
<div id="DataRow" class="col-md-12">
<div class="panel panel-info">
<div class="panel-heading">
<h3 class="panel-title">
<div class="pull-right">
<a class="btn btn-warning btn-xs" data-toggle="collapse" data-parent="#DataRow" href="#CollapseData" aria-expanded="true" aria-controls="CollapseData">
<span class="glyphicon glyphicon-collapse-down"></span>
</a>
Data
<button class="btn btn-danger btn-xs disabled" id="DownloadBtn" type="button" title="Download all data"><span class="glyphicon glyphicon-download-alt" aria-hidden="true"></span> Download</button>
</div>
</h3>
</div>
<div id="CollapseData" class="panel-collapse collapse in" role="tabpanel" aria-labelledby="headingOne">
<div class="panel-body">
<div class="form-inline col-sm-12 move-down-sm">
Controls will be displayed here
</div>
<div class="form-horizontal col-sm-12 move-down-sm">
Controls will be displayed here
</div>
<div class="form-inline col-sm-12 move-down-sm">
Controls will be displayed here
</div>
</div>
<div class="panel-footer">
<button class="btn btn-success btn-xs" id="SaveChangesBtn" type="button" title="Save the changes"><span class="glyphicon glyphicon-floppy-save" aria-hidden="true"></span> Save Changes</button>
</div>
</div>
</div>
</div>
期望:
答案 0 :(得分:2)
您需要在浮动项目周围创建新的block formatting context。这可以在several ways中完成。我已经使用overflow: hidden
:https://jsfiddle.net/r30ebnfs/
另一种可接受的方法是使用以下方法:
.panel-title {
display:inline-block;
vertical-align: top;
width: 100%;
}
https://jsfiddle.net/r30ebnfs/1/
编辑:
另一种方法是根本不浮动并使用引导样式(使用text-right
):
<h3 class="panel-title text-right">
<div class="">
<a class="btn btn-warning btn-xs" data-toggle="collapse" data-parent="#DataRow" href="#CollapseData" aria-expanded="true" aria-controls="CollapseData">
<span class="glyphicon glyphicon-collapse-down"></span>
</a>
Data
<button class="btn btn-danger btn-xs disabled" id="DownloadBtn" type="button" title="Download all data"><span class="glyphicon glyphicon-download-alt" aria-hidden="true"></span> Download</button>
</div>
</h3>
答案 1 :(得分:2)
元素通常根据其中的内容获得高度。浮动元素通常不会对该高度有贡献,因此如果元素具有浮动子元素,则如果这些元素是唯一的嵌套元素,则其内容高度将降至零。
有两种方法可以解决此问题,包括清除浮动。
<div id="someContainerWithFloatingChildren">
<div class="floatingLeft"></div> <!-- or right, or both, doesn't matter-->
<div class="clear"></div> <!-- empty element that clears the float -->
</div>
.clear {
clear: both;
}
或者您可以使用clearfix,这是一个使用伪元素来完成此清除div正在执行的操作的类,而不会使用空元素污染您的标记。我更喜欢这种方式:https://jsfiddle.net/99x50s2s/157/
有关clearfix的更多信息:https://css-tricks.com/snippets/css/clear-fix/