标题重写为:使用Flexbox实现元素的水平和垂直居中
P粉748218846
2023-08-20 13:00:18
<p>如何使用flexbox在容器中水平和垂直居中div。在下面的示例中,我希望每个数字都在下面(按行)居中。</p>
<p><br /></p>
<pre class="brush:css;toolbar:false;">.flex-container {
padding: 0;
margin: 0;
list-style: none;
display: flex;
align-items: center;
justify-content: center;
}
row {
width: 100%;
}
.flex-item {
background: tomato;
padding: 5px;
width: 200px;
height: 150px;
margin: 10px;
line-height: 150px;
color: white;
font-weight: bold;
font-size: 3em;
text-align: center;
}</pre>
<pre class="brush:html;toolbar:false;"><div class="flex-container">
<div class="row">
<span class="flex-item">1</span>
</div>
<div class="row">
<span class="flex-item">2</span>
</div>
<div class="row">
<span class="flex-item">3</span>
</div>
<div class="row">
<span class="flex-item">4</span>
</div>
</div></pre>
<p><br /></p>
<p>http://codepen.io/anon/pen/zLxBo</p>
如何在Flexbox中垂直和水平居中元素
下面是两种常见的居中解决方案。
一种用于垂直对齐的弹性项目(
flex-direction: column
),另一种用于水平对齐的弹性项目(flex-direction: row
)。在这两种情况下,居中的div的高度可以是可变的,未定义的,未知的,不重要。
以下是两者的HTML代码:
CSS(不包括装饰样式)
当弹性项目垂直堆叠时:
演示
当弹性项目水平堆叠时:
调整上面代码中的
flex-direction
规则。演示
居中弹性项目的内容
弹性格式化上下文的范围仅限于父子关系。超出子代的弹性容器的后代不参与弹性布局,并将忽略弹性属性。基本上,弹性属性在子代之外不可继承。
因此,您始终需要将
display: flex
或display: inline-flex
应用于父元素,以便将弹性属性应用于子元素。为了垂直和/或水平居中文本或其他内容,使项目成为(嵌套的)弹性容器,并重复居中规则。
更多细节请参见:如何在flexbox中垂直对齐文本?
或者,您可以将
margin: auto
应用于弹性项目的内容元素。在这里了解有关弹性
auto
边距的更多信息:对齐弹性项目的方法(参见box#56)。居中多行弹性项目
当弹性容器有多行(由于换行)时,
align-content
属性将对交叉轴对齐至关重要。来自规范:
更多细节请参见:flex-wrap如何与align-self,align-items和align-content一起工作?
浏览器支持
所有主要浏览器都支持Flexbox,除了IE < 10。一些最近的浏览器版本,如Safari 8和IE10,需要供应商前缀。为了快速添加前缀,可以使用Autoprefixer。更多详细信息请参见这个答案。
旧浏览器的居中解决方案
有关使用CSS表格和定位属性的替代居中解决方案,请参见此答案:https://stackoverflow.com/a/31977476/3597276
我认为你想要的是以下内容。