flex布局是什么
flex是flexible box的缩写,意为“弹性布局”。
基本概念
flex容器:采用flex布局的元素,称为flex容器,简称容器
flex项目:所有子元素自动成为容器成员,成为flex项目,简称项目
容器默认有两根轴:水平的主轴和垂直的交叉轴
容器的属性
- flex-direction
- flex-wrap
- flex-flow
- justify-content
- align-items
- align-content
flex-direction
决定主轴的方向,即项目的排列方向
- row 默认值 主轴为水平方向,起点在左端
- row-reverse 主轴为水平方向,起点在右端
- column: 主轴为垂直方向,起点在上沿
- column-reverse :主轴为垂直方向,起点在下沿
flex-wrap
默认情况下,项目都排列在一条线(轴线)上,flex-wrap 属性定义一条轴线排不下,换行方式
- nowrap 默认,不换行
- wrap 换行,第一行在上方
- wrap-reverse 换行,第一行在下方
flex-flow
是flex-direction 和 flex-wrap 属性的简写。默认值为 row nowrap
justify-content
定义了项目在主轴上的对齐方式
- flex-start 默认值,左对齐
- flex-end 右对齐
- center 居中
- space-between 两端对齐,项目之间的间隔都相等
- space-around 每个项目两侧的间隔相等(项目之间的间隔比项目与边框的间隔大一倍)
align-items
定义项目在交叉轴上如何对齐
- flex-start 交叉轴的起点对齐
- flex-end 交叉轴的终点对齐
- center 交叉轴的中点对齐
- baseline 项目的第一行文字的基线对齐
- stretch 默认值,如果项目未设置高度或设为auto,将沾满整个容器的高度
align-content
定义了多根轴线的对齐方式,如果项目只有一根轴线,该属性不起作用
- flex-start 与交叉轴的起点对齐
- flex-end 与交叉轴的终点对齐
- center 与交叉轴的中点对齐
- space-between 与交叉轴两端对齐,轴线之间的间隔平均分布
- space-around 每根轴线两侧的间隔都相等,所以轴线之间的间隔比轴线与边框的间隔大一倍
- stretch 默认值,轴线沾满整个交叉轴
inline-flex
行内元素
居中实现 给父级元素设置
text-align:center
项目的属性
- order
- flex-grow
- flex-shrink
- flex-basis
- flex
- align-self
order
定义项目的排列顺序,数值越小,排列越靠前,默认为0
flex-grow
定义项目的放大比例,默认为0,即如果存在剩余空间,也不放大
flex-shrink
定义了项目的缩小比例,默认为1,即如果空间不足,该项目将缩小
flex-basis
定义了在分配多余空间之前,项目占据的主轴空间。浏览器根据这个属性,计算主轴是否有多余空间。它的默认值为auto,即项目的本来大小
flex
是flex-grow flex-shrink 和 flex-basis 的简写。默认值为0 1 auto.
该属性有两个快捷键 auto( 1 1 auto) 和none (0 0 auto)
align-self
允许单个项目有与其他项目不一样的对齐方式,可覆盖align-items 属性,默认值为auto,表示继承父元素的align-items属性,如果没有父元素,则等同于stretch
initial
元素会根据自身宽高设置尺寸。它会缩短自身以适应 flex 容器,但不会伸长并吸收 flex 容器中的额外自由空间来适应 flex 容器 。相当于将属性设置为”flex: 0 1 auto
“。
auto
元素会根据自身的宽度与高度来确定尺寸,但是会伸长并吸收 flex 容器中额外的自由空间,也会缩短自身来适应 flex 容器。这相当于将属性设置为 “flex: 1 1 auto
“
none
元素会根据自身宽高来设置尺寸。它是完全非弹性的:既不会缩短,也不会伸长来适应 flex 容器。相当于将属性设置为”flex: 0 0 auto
“。
[flex-grow](https://developer.mozilla.org/zh-CN/docs/Web/CSS/flex-grow)
, [flex-shrink](https://developer.mozilla.org/zh-CN/docs/Web/CSS/flex-shrink)
与 [flex-basis](https://developer.mozilla.org/zh-CN/docs/Web/CSS/flex-basis)
flex-grow 定义项目的放大比例。默认为0,即如果存在剩余空间,也不放大
flex-shrink 定义了项目的缩小比例,默认为1,即如果空间不足,该项目将缩小
flex-basis 定义了在分配多余空间之前,项目占据的主轴空间
flex 简写 flex-grow flex-shrink flex-basis 默认值为0 1 auto
单值语法:值必须为以下其中之一
- 一个无单位数(number):它会被当做
的值 - 一个有效的宽度(width): 它会被当做
的值 - 关键字 none auto 或 initial
双值语法:第一个值必须为一个无单位数,并且它会被当做
- 一个无单位数:
的值 - 一个有效的宽度值:
的值
常用属性以及使用方法
容器的属性
flex-direction 决定主轴的方向
flex-wrap 换行(默认是一条线的)
flex-flow 属性是flex-direction和flex-wrap的简写 默认值为row nowrap 可设置 wrap
justify-content 定义了项目在主轴上的对齐方式
align-items 定义项目在交叉轴上如何对齐
align-content 定义了多根轴线的对齐方式,如果项目只有一根轴线,则不起作用
项目的属性
order 定义项目的排列顺序,数值越小,排列越靠前,默认为0;
.item{
order:<integer>
}
flex-grow 定义项目的放大比例。默认为0,即如果存在剩余空间,也不放大
flex-shrink 定义了项目的缩小比例,默认为1,即如果空间不足,该项目将缩小
flex-basis 定义了在分配多余空间之前,项目占据的主轴空间
flex 简写 flex-grow flex-shrink flex-basis 默认值为0 1 auto
align-self(单个) 允许单个项目有与其他项目不一样的对齐方式,可覆盖align-items属性
flex: 三值语法
- 第一个值必须为一个无单位数,并且它会被当作
[<flex-grow>](https://developer.mozilla.org/zh-CN/docs/Web/CSS/flex-grow)
的值。 - 第二个值必须为一个无单位数,并且它会被当作
[<flex-shrink>](https://developer.mozilla.org/zh-CN/docs/Web/CSS/flex-shrink)
的值。 - 第三个值必须为一个有效的宽度值, 并且它会被当作
[<flex-basis>](https://developer.mozilla.org/zh-CN/docs/Web/CSS/flex-basis)
的值。
场景:网页端需要元素大小自适应时
flex: 1 1 0% ;
常见实际应用
商品分类的布局 一行三个或者一行四个的排列
九宫格的布局排列
资料链接
https://www.zhangxinxu.com/wordpress/2018/10/display-flex-css3-css/
一行n个,且有间隔的布局
注意:
- 当外层容器有高度的时候, align-content 这个属性需要设置,不然会导致每行的内容在整个盒子中不是接着下面排列的。
- 当外层容器没有高度时,一切正常。
使用margin的情况来 让子元素之间有间隙
.content{
width: 500px;
height: 500px; //高度
border: 1px solid black;
display: flex;
flex-wrap: wrap;
align-content: flex-start;
}
.item{
width: 20%;
height: 100px;
background-color: red;
margin-right: 10px;
margin-bottom: 10px;
}
<div class="content">
<div class="item"></div>
<div class="item"></div>
<div class="item"></div>
<div class="item"></div>
<div class="item"></div>
<div class="item"></div>
<div class="item"></div>
</div>
九宫格布局
实则跟上面的布局是一样的结构。
如果不使用margin来让子元素之间有间隙。
.content{
width: 500px;
border: 1px solid black;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
.item{
width: 30%;
height: 100px;
background-color: red;
margin-bottom: 10px;
}
<div class="content">
<div class="item"></div>
<div class="item"></div>
<div class="item"></div>
<div class="item"></div>
<div class="item"></div>
<div class="item"></div>
<div class="item"></div>
<div class="item"></div>
<div class="item"></div>
</div>
jusitify-content 对齐问题
https://www.zhangxinxu.com/wordpress/2019/08/css-flex-last-align/
场景:最后一行的列表的个数不满,则就会出现这种问题
模拟space-between 和 间隙
.container {
display: flex;
flex-wrap: wrap;
}
.list {
width: 24%; height: 100px;
background-color: skyblue;
margin-top: 15px;
}
.list:not(:nth-child(4n)) {
margin-right: calc(4% / 3);
}
flex布局设置单个子元素靠右
在flex布局中 父元素设置了
display: -webkit-flex;
display: flex;
align-items: center;
子元素是水平轴对齐的,如果想设置单个子元素靠右
1.
flex: 1;
text-align: right;
2.
margin-left: auto;
(常)最后一行元素对齐问题
1.添加几个空item
根据布局列数添加空item,比如每行最大n列,那么在最后添加n-2个空item即可
<html>
<style>
.item {
width: 32%;
background-color: #00abff;
height: 60px;
margin-top: 10px;
}
.itemempty {
height: 0px;
width: 32%;
}
.box {
display: flex;
justify-content: space-between;
flex-wrap: wrap;
}
</style>
<body>
<div class="box">
<div class="item"></div>
<div class="item"></div>
<div class="item"></div>
<div class="item"></div>
<div class="item"></div>
<div class="item"></div>
<div class="item"></div>
<div class="item"></div>
<div class="itemempty"></div>
<div class="itemempty"></div>
<div class="itemempty"></div>
</div>
</body>
</html>
2.利于after(适用于每行列数确定的场景)
注意:是给最外层的元素添加 不是里面的子元素
.box:after {
content: "";
flex: auto;
}
还可以使用 margin并且去除最后一行margin-right 实现
flex页面整体布局
场景:上下布局
<div class="container">
<div class="header"></div>
<div class="content">
<div class="left"></div>
<div class="center"></div>
<div class="right"></div>
</div>
</div>
<style>
.container{
display: flex;
flex-direction: column;
}
.header{
height: 100px;
}
.content{
flex:1;
/* 重点 */
height: 0;
}
/* left区域当超出时可以滚动 */
.right{
height: 100%;
overflow: hidden;
overflow-y: scroll;
}
</style>
flex:1 代表什么
flex: 1 === flex: 1 1 任意数字+任意长度单位;
https://zhuanlan.zhihu.com/p/136223806
flex 中固定宽度不生效
<view class="intro">
<view class="list">
<view class="grid">1</view>
<view class="grid">2</view>
<view class="grid">3</view>
<view class="grid">4</view>
<view class="grid">5</view>
<view class="grid">6</view>
<view class="grid">7</view>
</view>
</view>
.list {
display: flex;
overflow-x: scroll;
}
.grid {
margin-left: 10rpx;
width: 150rpx;
height: 58rpx;
border: 1rpx solid #e5e5e5;
flex-shrink:1; //add
}
flex-shrink 定义了项目的缩小比例,默认为1,即如果空间不足,该项目将缩小。
flex 元素仅在默认宽度之和大于容器的时候才会发生收缩,其收缩的大小是依据 flex-shrink 的值
如果所有项目的 flex-shrink 属性都为1,当空间不足时,都将等比例缩小、如果一个项目的 flex-shrink 属性为0,其他项目都为1,则空间不足时,前者不缩小。
左侧固定,右侧自适应
.container{
display: flex;
/* width: 800px; */
}
.left{
border: 1px solid black;
width: 600px;
flex-shrink: 0
}
.right{
border: 1px solid black;
flex: 1;
}
flex-shrink,默认值是1,修改为0,就不会因为右侧内容太多,被压缩。