flex
在css布局中的是一个经常考察的知识点,虽然垂直居中问题已经问得快烂大街了,flex
你虽然总是在用,但是总会有你不知道的盲点
本文是一篇关于flex
布局相关的总结笔记,遇到比较刁钻的问题,当个知识拓展吧
在阅读本文之前,主要从以下几个方向去探讨flex
- flex布局又称为弹性布局,有何特征
- 关于flex的一些属性值
flex
如何实现垂直居中,如何实现一个对角排列布局
flex特征
当我们对一个元素设置flex
后,其子元素所有的float
,clean
、vertical-align
属性都会失效,并且默认水平排列,并且宽度由自身元素内容决定。
影响主轴与交叉轴的属性——
- flex-direction
主要影响水平轴排列还是交叉轴排列
.wrap-box {
display: flex;
// flex-direction: row; 默认从左往右
flex-direction: row-revers; 顺序从右往左
flex-direction: column; 从上往下
flex-direction: column-reverse; 从下往上
}
- flex-wrap 主要影响水平轴元素是否换行,默认不换行
flex-wrap:nowrap
.wrap-box {
display: flex;
flex-direction: row;
flex-wrap: nowrap // 不换行
// flex-wrap: wrap // 换行
// flex-wrap: wrap-reverse 换行从下往上依次排列
}
- flex-flow
这个属性主要是flex-direction
与flex-wrap
的结合体
.wrap-box {
display: flex;
flex-flow: row nowrap // 默认
}
- justify-content
主要影响水平主轴
的排列顺序
.wrap-box {
display: flex;
justify-content: flex-start // 左对齐排列
// justify-content: center // 居中排列
// justify-content: space-between // 两端对齐排列
// justify-content: space-around // 间隔相等排列
// justify-content: flex-end // 居右排列
}
- align-items
主要影响交叉轴
垂直方向的排列
.wrap-box {
display: flex;
align-items: flex-start; // 垂直方向从上往下排列
// align-items: center 垂直方向居中排列
// align-items: flex-end 垂直方向从下往上排列
// align-items: stretch 会将子元素高度拉伸父元素一致(子元素未设置高度)
}
关于item项目设置的属性
- order
决定子项目的顺序,order
越小,越是排列在最前面
假设现在有个需求,css实现简单的跑马灯
<div class="wrap-box">
<div class="item-1">1</div>
<div class="item-2">2</div>
<div class="item-3">3</div>
</div>
@keyframes ani-1 {
0% {
order: 0;
}
50% {
order: 1;
}
100% {
order: 2;
}
}
@keyframes ani-2 {
0% {
order: 1;
}
50% {
order: 0;
}
100% {
order: 1;
}
}
@keyframes ani-3 {
0% {
order: 2;
}
50% {
order: 2;
}
100% {
order: 0;
}
}
.wrap-box {
width: 500px;
height: 500px;
overflow: hidden;
display: flex;
background-color: green;
align-items: stretch;
}
.wrap-box .item-1,
.wrap-box .item-2,
.wrap-box .item-3 {
width: 100px;
height: 100px;
background-color: red;
}
.wrap-box .item-1 {
animation: ani-1 5s infinite;
transition: order 1s ease;
}
.wrap-box .item-2 {
animation: ani-2 5s infinite;
transition: order 1s ease;
}
.wrap-box .item-3 {
animation: ani-3 5s infinite;
transition: order 1s ease;
}
我们利用css3
的动画帧,改变order的顺序,因此一个简易的css跑马灯就实现了,而且并没有改变dom
的结构和顺序
- flex-basis
设置当前的item的固定宽度
.wrap-box .item-3{
flex-basis: 200px;
}
- flex-grow
该属性是决定当前item的放大比例,默认是0
比如三个div,左右固定,中间内容自动撑开
- flex-shrink
当前item的缩小比例,默认的是0
- align-self
能控制单个item
的排列,这个属性通常不是很常用,面试曾被这个css的属性布局问题给跪了
面试题大概是这样的,3个子div实现一个对角线布局,用flex布局
,如果没想到这个align-self
大概是实现不了
.wrap-box {
width: 500px;
height: 500px;
overflow: hidden;
background-color: green;
display: flex;
justify-content: space-between;
}
.wrap-box .item-1,
.wrap-box .item-2,
.wrap-box .item-3 {
width: 100px;
height: 100px;
background-color: red;
}
.wrap-box .item-2 {
align-self: center; // 垂直居中
}
.wrap-box .item-3 {
align-self: flex-end; // 靠右
}
设置对应的item
大概就是下面这样了
关于flex:1的详解
通常我们设置flex:1
,其实本质上是替代了以下几个参数
.item3 {
flex-grow:1;
flex-shrink:1;
flex-basis: 0%;
}
元素垂直居中
以下是一个基本的页面结构
<div class="wrap">
<div class="inner-box"></div>
</div>
.wrap {
width: 100px;
height: 100px;
display: flex;
justify-content: center;
align-items: center;
background-color: red;
}
.wrap .inner-box {
width: 50px;
height: 50px;
background: green;
}
总结
了解flex基本特征,影响水平轴与交叉轴的的属性主要受
flex-direction
这个属性的,默认水平row
排列当一个父级元素设置
flex
后,子级的浮动
、clear
,vertain-align
属性都会失效,默认所有子级元素水平排列flex
的一些特性,比如放大flex-glow
、缩小flex-shrink
,还有影响水平轴排列just-content
,以及交叉轴排列align-items
属性的设置align-self 这个属性可以单独控制当前元素的位置
flex实现一个垂直居中