一、 flex 布局(弹性布局)基础知识
1. flex 布局中常用术语(三个二)
序号 |
简记 |
术语 |
1 |
二成员 |
容器和项目(container / item ) |
2 |
二根轴 |
主轴与交叉轴(main-axis / cross-axis ) |
3 |
二根线 |
起始线与结束线(flex-start / flex-end ) |
2. display
属性
序号 |
属性值 |
描述 |
备注 |
1 |
flex; |
创建 flex 块级容器 |
内部子元素自动成为 flex 项目 |
2 |
inline-flex; |
创建 flex 行内容器 |
内部子元素自动成为 flex 项目,多个inline-flex; 才有效果 |
3.flex 容器属性
序号 |
属性 |
描述 |
1 |
flex-direction |
设置容器中的主轴方向: 行/水平方向, 列/垂直方向 |
2 |
flex-wrap |
是否允许创建多行容器,即 flex 项目一行排列不下时, 是否允许换行 |
3 |
flex-flow |
简化 flex-direction, flex-wrap 属性 |
4 |
justify-content |
设置 flex 项目在主轴上对齐方式 |
5 |
align-items |
设置 flex 项目在交叉轴上对齐方式 |
6 |
align-content |
多行容器中,项目在交叉轴上的对齐方式 |
4.flex 容器属性
序号 |
属性 |
描述 |
1 |
flex-basis |
项目宽度: 项目分配主轴剩余空间之前, 项目所占据的主轴空间宽度 |
2 |
flex-grow |
项目的宽度扩展: 将主轴上的剩余空间按比例分配给指定项目 |
3 |
flex-shrink |
项目的宽度收缩: 将项目上多出空间按比例在项目间进行缩减 |
4 |
flex |
是上面三个属性的简化缩写: flex: flex-grow flex-shrink flex-basis |
5 |
align-self |
单独自定义某个项目在交叉轴上的对齐方式 |
6 |
order |
自定义项目在主轴上的排列顺序,默认为 0,书写顺序,值越小位置越靠前 |
二、 代码演示 flex 属性
1、display
属性
<style>
.container {
width: 300px;
height: 150px;
/*设置容器为弹性容器,容器内项目自动转为弹性项目,默认水平排列*/
/*display: flex;*/
display: inline-flex;
}
.container2 {
width: 300px;
height: 150px;
/*设置容器为弹性容器,容器内项目自动转为弹性项目,默认水平排列*/
/*display: flex;*/
display: inline-flex;
}
.item {
width: 100px;
height: 50px;
background-color: skyblue;
}
</style>
1.1 display: flex;
设置容器为弹性容器,容器内项目自动转为弹性项目
data:image/s3,"s3://crabby-images/cd8ef/cd8efd7729db030fe20989b3f30a87a89f76f3a6" alt=""
1.2 display: inline-flex;
:创建 flex 行内容器,多个才有效
data:image/s3,"s3://crabby-images/10cb0/10cb0812cea66855cab4fcdc27c3c12b92c8c3a7" alt=""
2、flex-wrap
:设置容器主轴方向
<style>
.container {
width: 300px;
height: 150px;
display: flex;
/*flex-direction: row;*/
/*flex-direction: row-reverse;*/
/*flex-direction: column;*/
flex-direction: column-reverse;
}
.item {
width: 100px;
height: 50px;
background-color: skyblue;
}
</style>
2.1 flex-direction:row;
:设置主轴方向:水平,默认值
data:image/s3,"s3://crabby-images/11f63/11f6335311fdc5b270c7671cbeffa0803d64b649" alt=""
2.2 flex-direction: row-reverse;
:设置主轴方向:水平,右到左
data:image/s3,"s3://crabby-images/d1541/d15418e4a70e15b84bf36e004f6704fc73b83d78" alt=""
2.3 flex-direction: column;
:设置主轴方向:垂直,上到下
data:image/s3,"s3://crabby-images/b9efc/b9efcbfbf17ad3bc911704c859ec9d112da4203d" alt=""
2.4 flex-direction: column;
:设置主轴方向:垂直,下到上
data:image/s3,"s3://crabby-images/f11ee/f11eeb33aac009d9057783863ca39f63ab9a4dca" alt=""
3、flex-wrap
:设置项目在容器主轴是否换行
<style>
.container {
width: 300px;
height: 150px;
display: flex;
/*flex-wrap: nowrap;*/
/*flex-wrap: wrap;*/
flex-wrap: wrap-reverse;
}
.item {
width: 100px;
height: 50px;
background-color: skyblue;
}
</style>
3.1 flex-wrap: nowrap;
:默认值,不换行,如果当前容器容纳不小, 项目会自动收缩
data:image/s3,"s3://crabby-images/ee92d/ee92d5a7505f4fce81984ab97c54abb53494a4fd" alt=""
3.2 lex-wrap: wrap;
:换行, 当前行容纳不下的项目会换行显示,此时,创建的容器叫:多行容器
data:image/s3,"s3://crabby-images/060b5/060b516ad2adbd2bed6b3fcd730d0df9f9b96e0e" alt=""
3.3 flex-wrap: wrap-reverse;
:换行,反向
data:image/s3,"s3://crabby-images/0d265/0d26513e90d096efab73d98507cf3aebc35ce403" alt=""
4、flex-flow: row nowrap;
:设置容器主轴与项目是否换行简写
<style>
.container {
width: 300px;
height: 150px;
display: flex;
/*flex-flow: row nowrap;*/
/*flex-flow: row wrap;*/
/*flex-flow: row wrap-reverse;*/
/*flex-flow: column nowrap;*/
/*flex-flow: column wrap;*/
flex-flow: column wrap-reverse;
}
.item {
width: 100px;
height: 50px;
background-color: skyblue;
}
</style>
4.1 flex-flow: row nowrap;
:水平,不换行
data:image/s3,"s3://crabby-images/577d5/577d50c30c7dcbd186ec3d95247e130bf5443ef3" alt=""
4.2 flex-flow: row wrap;
:水平,换行
data:image/s3,"s3://crabby-images/7220b/7220b2d5522ae2267151e7668a56cdc78f10c2f4" alt=""
4.3 flex-flow: row wrap-reverse;
:水平,换行,反向
data:image/s3,"s3://crabby-images/6f9aa/6f9aaaa50ad9e805f8df1bc96d31e5613d1b0545" alt=""
4.4 flex-flow: column nowrap;
:垂直,不换行(列)
data:image/s3,"s3://crabby-images/c2397/c239774b21462c711b386c47161fe861e7bdd2e7" alt=""
4.5 flex-flow: column wrap;
:垂直,换行(列)
data:image/s3,"s3://crabby-images/4d05c/4d05cc8a387649459e3e06c214ac448f1753d45a" alt=""
4.6 flex-flow: column wrap-reverse;
:垂直,换行(列),反向
data:image/s3,"s3://crabby-images/9b912/9b912d22a6196ec99bc5f1c5215000f504c4f70c" alt=""
5、justify-content
:弹性项在目容器主轴上的对齐方式
<style>
.container {
width: 400px;
height: 150px;
display: flex;
/*justify-content: flex-start;*/
/*justify-content: flex-end;*/
/*justify-content: center;*/
/*justify-content: space-between;*/
/*justify-content: space-around;*/
justify-content: space-evenly;
}
.item {
width: 80px;
height: 50px;
background-color: skyblue;
}
</style>
5.1 justify-content: flex-start;
:主轴起始线对齐,默认
data:image/s3,"s3://crabby-images/eaec3/eaec3097041b7b2804c3c80aabc4189c9870048c" alt=""
5.2 display: inline-flex;
:主轴终止线对齐
data:image/s3,"s3://crabby-images/888e7/888e77443ae4fe0c0e96e38bb185ae768fba1104" alt=""
5.3 display: inline-flex;
:居中对齐
data:image/s3,"s3://crabby-images/9915f/9915f3a659356fed1317a65d5383b710f02279a2" alt=""
5.4 flex-wrap: nowrap;
:两端对齐—剩余空间在头尾项目之外的项目间平均分配
data:image/s3,"s3://crabby-images/bd837/bd837ff8d86bfd8a7479c9654c2654feba2f280f" alt=""
5.5 display: inline-flex;
:分散对齐—剩余空间在每个项目二侧平均分配
data:image/s3,"s3://crabby-images/af778/af778fbb775ce3fed972e584c469edad85516224" alt=""
5.6 display: inline-flex;
:平均对齐—剩余空间在每个项目之间平均分配
data:image/s3,"s3://crabby-images/0a883/0a88334635f446912f094296cef63dfb3b6a4403" alt=""
6、align-items
:容器交叉轴项目对齐
<style>
.container {
width: 300px;
height: 150px;
display: flex;
/*align-items: flex-start;*/
/*align-items: flex-end;*/
align-items: center;
}
.item {
width: 100px;
height: 50px;
background-color: skyblue;
}
</style>
6.1 align-items: flex-start;
:与交叉轴起始线对齐
data:image/s3,"s3://crabby-images/ef8d1/ef8d14baeccd673f6930f363d4c7a71a5f90143c" alt=""
6.2 align-items: flex-end;
:与交叉轴终止线对齐
data:image/s3,"s3://crabby-images/a8ec0/a8ec016ed89a7d289c699aa48593096ad5f0074d" alt=""
6.3 align-items: center;
:居中对齐
data:image/s3,"s3://crabby-images/f002b/f002ba8b2e6fd023f5fc3801bd7e15fbc8a3db11" alt=""
7、align-content
:多行容器中项目在交叉轴的对齐方式
<style>
.container {
width: 300px;
height: 200px;
display: flex;
/*设置换行变为多行容器*/
flex-wrap: wrap;
/*align-content: stretch;*/
/*align-content: flex-start;*/
/*align-content: flex-end;*/
/*align-content: center;*/
/*align-content: space-between;*/
/*align-content: space-around;*/
align-content: space-evenly;
}
.item {
width: 100px;
height: 50px;
background-color: skyblue;
}
</style>
7.1 align-content: stretch;
:项目拉伸占据整个交叉轴
data:image/s3,"s3://crabby-images/6eb19/6eb19b6496afa854fb481e87002088a75fc850e8" alt=""
7.2 align-content: flex-start;
:所有项目与交叉轴起始线(顶部)对齐
data:image/s3,"s3://crabby-images/6d6cc/6d6ccbec242413900d2a3389efc4258256c1bcc6" alt=""
7.3 align-content: flex-end;
:所有项目与交叉轴终止线对齐
data:image/s3,"s3://crabby-images/0f936/0f93698ff6c87970482f8fec47ff7710e0d31177" alt=""
7.4 align-content: center;
:所有项目与交叉轴中间线对齐: 居中对齐
data:image/s3,"s3://crabby-images/e61e0/e61e005be59d8a6f04613ab82c1f75ab82966ae7" alt=""
7.5 align-content: space-between;
:两端对齐: 剩余空间在头尾项目之外的项目间平均分配
data:image/s3,"s3://crabby-images/a3ea2/a3ea258abf8f88b6eaa78d0a89007a63500845cd" alt=""
7.6 align-content: space-around;
:分散对齐: 剩余空间在每个项目二侧平均分配
data:image/s3,"s3://crabby-images/3a7bd/3a7bd0a4572ad03e5094327f4c783263dab92355" alt=""
7.7 align-content: space-evenly;
:平均对齐: 剩余空间在每个项目之间平均分配
data:image/s3,"s3://crabby-images/f755f/f755ff5a401b74713faacca73513dbadc3c5ef20" alt=""
8、align-self
:单独某个项目在交叉轴的对齐方式
- 该属性可覆盖容器的
align-items
, 用以自定义某个项目的对齐方式
8.1 align-self: auto;
:继承 align-items
属性值
8.2 align-self: flex-start;
:与交叉轴起始线对齐
8.3 align-self: flex-end;
:与交叉轴终止线对齐
8.4 align-self: center;
:与交叉轴中间线对齐: 居中对齐
8.5 align-self: stretch;
:在交叉轴方向上拉伸
8.6 align-self: baseline;
:与基线对齐(与内容相关用得极少)
<style>
.container {
width: 300px;
height: 200px;
display: flex;
}
.item {
width: 100px;
height: 50px;
background-color: skyblue;
}
.item:first-of-type {
background-color: lightcoral;
align-self: flex-start;
}
.item:nth-of-type(2) {
background-color: wheat;
align-self: flex-end;
}
.item:nth-of-type(3) {
align-self: center;
}
.item:nth-of-type(4) {
height: inherit;
align-self: stretch;
background-color: lightgreen;
}
.item:last-of-type {
align-self: baseline;
}
</style>
data:image/s3,"s3://crabby-images/67416/6741659fb05dd0e87751c10882a70600039c6749" alt=""
9、flex-grow
:项目放大因子:分配主轴剩余空间
9.1 flex-grow: 0; / flex-grow: initial;
:不放大,保持初始值
9.2 flex-grow: n;
:n为正数,创建 flex 行内容器
<style>
.container {
width: 480px;
height: 150px;
display: flex;
}
.item {
width: 80px;
height: 50px;
background-color: skyblue;
}
.item:first-of-type {
background-color: lightgreen;
flex-grow: 1;
}
.item:nth-of-type(2) {
background-color: lightcoral;
flex-grow: 2;
}
.item:last-of-type {
background-color: wheat;
flex-grow: 3;
}
</style>
data:image/s3,"s3://crabby-images/729f6/729f66662db8e9b5164546aa41f66ceb3574f9a7" alt=""
10、flex-shrink
:项目收缩因子:主轴空间小于项目空间时,收缩顶目空间
<style>
.container {
width: 300px;
height: 150px;
display: flex;
}
.item {
width: 120px;
height: 50px;
background-color: skyblue;
/*flex-shrink: 0;*/
}
.item:last-of-type {
/*flex-shrink: 0.5;*/
}
10.1 flex-shrink: 1; / flex-shrink: initial;
:允许项目收缩
10.2 flex-shrink: 0;
:禁止收缩
data:image/s3,"s3://crabby-images/28406/28406226dd0c23e9856324005fd24dc3bb19fd89" alt=""
10.3 flex-shrink: n;
:n为正数,创建 flex 行内容器
data:image/s3,"s3://crabby-images/bf71d/bf71dbfe3ad4f5d77ee7dd3616073a43389467bf" alt=""
11、flex-basis
:项目计算尺寸
- width < flex-basis < min/max-width;
<style>
/* 容器 */
.container {
width: 300px;
height: 150px;
display: flex;
flex-flow: row wrap;
}
/* 项目/子元素 */
.item {
width: 50px;
height: 50px;
background-color: skyblue;
}
.item {
/*auto === width 50px*/
/*flex-basis: auto;*/
flex-basis: 70px;
/*flex-basis: 20%;*/
/*flex-basis: 5rem;*/
/*max-width: 100px;*/
/*flex-basis: 150px;*/
}
</style>
12、flex
:项目缩放的简写
<style>
.container {
width: 300px;
height: 150px;
display: flex;
}
.item {
width: 100px;
height: 50px;
background-color: skyblue;
font-size: 1.5rem;
}
.item:first-of-type {
background-color: lightgreen;
/* 默认:不放大,允许收缩, 以项目的width为准 */
flex: 0 1 auto;
flex: 1 1 auto;
/* flex: 0 1 80px; */
}
.item:nth-of-type(2) {
background-color: lightcoral;
flex: 0 100px;
}
.item:last-of-type {
background-color: wheat;
flex: auto;
flex: 1;
flex: none;
flex: 0 0 auto;
flex: 0 0 250px;
}
</style>
12.1 三值语法: flex: flex-grow flex-shrink flex-basis
序号 |
案例 |
描述 |
1 |
flex: 0 1 auto |
默认值: 不放大,可收缩, 初始宽度 |
2 |
flex: 1 1 auto |
项目自动放大或收缩适应容器 |
3 |
flex: 0 0 100px |
按计算大小填充到容器中 |
12.2 二值语法: flex: flex-grow flex-basis
案例 |
描述 |
flex: 0 180px |
禁止放大,按计算大小填充到容器中 |
12.3 单值语法
序号 |
案例 |
描述 |
1 |
flex: 1 |
flex: 1 1 auto |
2 |
flex: 180px |
flex: 1 1 180px |
3 |
initial |
flex: 0 1 auto |
4 |
auto |
flex: 1 1 auto |
5 |
none |
flex: 0 0 auto |
三、 课程总结
1、flex
简写是难点,基础知识,多写,多记,可以先从flex
三值语法先熟悉。
2、flex: 1
、flex: 0
:比较常用,不理解可以,背下来。