flex
在css布局中的是一个经常考察的知识点,虽然垂直居中问题已经问得快烂大街了,flex
你虽然总是在用,但是总会有你不知道的盲点
本文是一篇关于flex
布局相关的总结笔记,遇到比较刁钻的问题,就当个知识拓展吧
在阅读本文之前,主要从以下几个方向去探讨flex
flex
如何实现垂直居中,如何实现一个对角排列布局当我们对一个元素设置flex
后,其子元素所有的float
,clean
、vertical-align
属性都会失效,并且默认水平排列,并且宽度由自身元素内容决定。
主要影响水平轴排列还是交叉轴排列
.wrap-box {
display: flex;
// flex-direction: row; 默认从左往右
flex-direction: row-revers; 顺序从右往左
flex-direction: column; 从上往下
flex-direction: column-reverse; 从下往上
}
flex-wrap:nowrap
.wrap-box {
display: flex;
flex-direction: row;
flex-wrap: nowrap // 不换行
// flex-wrap: wrap // 换行
// flex-wrap: wrap-reverse 换行从下往上依次排列
}
这个属性主要是flex-direction
与flex-wrap
的结合体
.wrap-box {
display: flex;
flex-flow: row nowrap // 默认
}
主要影响水平主轴
的排列顺序
.wrap-box {
display: flex;
justify-content: flex-start // 左对齐排列
// justify-content: center // 居中排列
// justify-content: space-between // 两端对齐排列
// justify-content: space-around // 间隔相等排列
// justify-content: flex-end // 居右排列
}
主要影响交叉轴
垂直方向的排列
.wrap-box {
display: flex;
align-items: flex-start; // 垂直方向从上往下排列
// align-items: center 垂直方向居中排列
// align-items: flex-end 垂直方向从下往上排列
// align-items: stretch 会将子元素高度拉伸父元素一致(子元素未设置高度)
}
决定子项目的顺序,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>
对应的css
@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
的结构和顺序
设置当前的item的固定宽度
.wrap-box .item-3{
flex-basis: 200px;
}
该属性是决定当前item的放大比例,默认是0
比如三个div,左右固定,中间内容自动撑开
当前item的缩小比例,默认的是0
能控制单个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
,其实本质上是替代了以下几个参数
.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-direction
这个属性的,默认水平row
排列flex
后,子级的浮动
、clear
,vertain-align
属性都会失效,默认所有子级元素水平排列flex
的一些特性,比如放大flex-glow
、缩小flex-shrink
,还有影响水平轴排列just-content
,以及交叉轴排列align-items
属性的设置[1]code example: https://github.com/maicFir/lessonNote/tree/master/html/04-flex布局
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有