场景
Flex是Flexible Box的缩写,意为”弹性布局”。
怎样使用弹性布局实现页面上下两个元素上下左右垂直居中排列。
实现如下类似布局
最外层是是一个div,div里面是上面一个照片,下面一个表单,这两个元素居中排列。
注:
实现
1、外层div设置样式
.login {
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
}
2、display: flex; 设置为弹性布局
3、flex-direction属性决定主轴的方向(即项目的排列方向)。
row(默认值):主轴为水平方向,起点在左端。
row-reverse:主轴为水平方向,起点在右端。
column:主轴为垂直方向,起点在上沿。
column-reverse:主轴为垂直方向,起点在下沿。
4、justify-content属性定义了项目在主轴上的对齐方式。
flex-start(默认值):左对齐
flex-end:右对齐
center: 居中
space-between:两端对齐,项目之间的间隔都相等。
space-around:每个项目两侧的间隔相等。所以,项目之间的间隔比项目与边框的间隔大一倍。
5、align-items属性定义项目在交叉轴上如何对齐。
flex-start:交叉轴的起点对齐。
flex-end:交叉轴的终点对齐。
center:交叉轴的中点对齐。
baseline: 项目的第一行文字的基线对齐。
stretch(默认值):如果项目未设置高度或设为auto,将占满整个容器的高度。
6、这样设置之后div里面上下两个元素就会居中
但是两个子元素会紧挨在一起,如果要使其有一定距离。
给下面的子元素设置margin-top属性即可
.login-form {
margin-top: 100px;
}