场景
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;
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/136045.html