Correcting teacher:天蓬老师
Correction status:qualified
Teacher's comments:你的代码呢?下次加上
序号 | 简记 | 术语 |
---|---|---|
1 | 二成员 | 容器和项目(container / item ) |
2 | 二根轴 | 主轴与交叉轴(main-axis / cross-axis ) |
3 | 二根线 | 起始线与结束线(flex-start / flex-end ) |
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>flex弹性布局</title>
<style>
/* 容器 */
.container {
width: 300px;
height: 150px;
}
/* 将容器/父元素设置为flex容器,布局只针对子元素、对孙子元素无效 */
.container {
display: flex;
/* inline-flex是针对多个容器的布局 */
display: inline-flex;
}
/* 项目/子元素 */
.item {
width: 100px;
height: 50px;
background-color: aqua;
font-size: 2rem;
}
</style>
</head>
<body>
<!-- .container>.item{项目}*4 -->
<!-- .container>.item{$}*4 -->
<div class="container">
<div class="item">1</div>
<div class="item">2</div>
<div class="item">3</div>
<div class="item">4</div>
</div>
<div class="container">
<div class="item">1</div>
<div class="item">2</div>
<div class="item">3</div>
<div class="item">4</div>
</div>
</body>
</html>
运行效果图:
总结: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 |
多行容器中,项目在交叉轴上的对齐方式 |
序号 | 属性 | 描述 |
---|---|---|
1 | flex-basis |
项目宽度: 项目分配主轴剩余空间之前, 项目所占据的主轴空间宽度 |
2 | flex-grow |
项目的宽度扩展: 将主轴上的剩余空间按比例分配给指定项目 |
3 | flex-shrink |
项目的宽度收缩: 将项目上多出空间按比例在项目间进行缩减 |
4 | flex |
是上面三个属性的简化缩写: flex: flex-grow flex-shrink flex-basis |
5 | align-self |
单独自定义某个项目在交叉轴上的对齐方式 |
6 | order |
自定义项目在主轴上的排列顺序,默认为 0,书写顺序,值越小位置越靠前 |
display
属性序号 | 属性值 | 描述 | 备注 |
---|---|---|---|
1 | flex; |
创建 flex 块级容器 | 内部子元素自动成为 flex 项目 |
2 | inline-flex; |
创建 flex 行内容器 | 内部子元素自动成为 flex 项目 |
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>flex弹性布局</title>
<style>
/* 容器 */
.container {
width: 300px;
height: 150px;
}
/* 将容器/父元素设置为flex容器,布局只针对子元素、对孙子元素无效 */
.container {
display: flex;
/* inline-flex是针对多个容器的布局 */
display: inline-flex;
}
/* 项目/子元素 */
.item {
width: 100px;
height: 50px;
background-color: aqua;
font-size: 2rem;
}
</style>
</head>
<body>
<!-- .container>.item{项目}*4 -->
<!-- .container>.item{$}*4 -->
<div class="container">
<div class="item">1</div>
<div class="item">2</div>
<div class="item">3</div>
<div class="item">4</div>
</div>
<div class="container">
<div class="item">1</div>
<div class="item">2</div>
<div class="item">3</div>
<div class="item">4</div>
</div>
</body>
</html>
运行效果图
总结:inline-flex:用于多个容器排序
序号 | 容器/项目 | 默认行为 |
---|---|---|
1 | 容器主轴 | 水平方向 |
2 | 项目排列 | 沿主轴起始线排列(当前起始线居左) |
3 | 项目类型 | 自动转换”行内块级”元素,不管之前是什么类型 |
4 | 容器主轴空间不足时 | 项目自动收缩尺寸以适应空间变化,不会换行显示 |
5 | 容器主轴存在未分配空间时 | 项目保持自身大小不会放大并充满空间 |
flex-direction
属性序号 | 属性值 | 描述 |
---|---|---|
1 | row 默认值 |
主轴水平: 起始线居中,项目从左到右显示 |
2 | row-reverse |
主轴水平:起始线居右, 项目从右向左显示 |
3 | column |
主轴垂直: 起始线居上,项目从上向下显示 |
4 | column-reverse |
主轴垂直: 起始线居下,项目从下向上显示 |
flex-wrap
属性序号 | 属性值 | 描述 |
---|---|---|
1 | nowrap 默认值 |
项目不换行: 单行容器 |
2 | wrap |
项目换行: 多行容器,第一行在上方 |
3 | wrap-reverse |
项目换行: 多行容器,第一行在下方 |
运行效果图:
总结:项目换行显示与不换行显示
flex-flow
属性flex-flow
是属性flex-direction
和flex-wrap
的简写flex-flow: flex-direction flex-wrap
属性值 | 描述 |
---|---|
row nowrap 默认值 |
主轴水平, 项目不换行 |
以后推荐只用它
运行效果:
flex-flow是flex和direction的集合简化体,注意属性值是双值
justify-content
属性当容器中主轴方向上存在剩余空间时, 该属性才有意义
序号 | 属性值 | 描述 |
---|---|---|
1 | flex-start 默认 |
所有项目与主轴起始线对齐 |
2 | flex-end |
所有项目与主轴终止线对齐 |
3 | center |
所有项目与主轴中间线对齐: 居中对齐 |
4 | space-between |
两端对齐: 剩余空间在头尾项目之外的项目间平均分配 |
5 | space-around |
分散对齐: 剩余空间在每个项目二侧平均分配 |
6 | space-evenly |
平均对齐: 剩余空间在每个项目之间平均分配 |
align-items
属性序号 | 属性值 | 描述 |
---|---|---|
1 | flex-start 默认 |
与交叉轴起始线对齐 |
2 | flex-end |
与交叉轴终止线对齐 |
3 | center |
与交叉轴中间线对齐: 居中对齐 |
运行效果:
总结:align-items交叉轴上的项目对齐方式,仅限单行容器
align-content
属性序号 | 属性值 | 描述 |
---|---|---|
1 | stretch 默认 |
项目拉伸占据整个交叉轴 |
1 | flex-start |
所有项目与交叉轴起始线(顶部)对齐 |
2 | flex-end |
所有项目与交叉轴终止线对齐 |
3 | center |
所有项目与交叉轴中间线对齐: 居中对齐 |
4 | space-between |
两端对齐: 剩余空间在头尾项目之外的项目间平均分配 |
5 | space-around |
分散对齐: 剩余空间在每个项目二侧平均分配 |
6 | space-evenly |
平均对齐: 剩余空间在每个项目之间平均分配 |
提示: 多行容器中通过设置
flex-wrap: wrap | wrap-reverse
实现
运行效果:
总结:多行容器的交叉轴项目对齐方式,与主轴的项目对齐方式有异曲同工之效
align-self
属性align-items
, 用以自定义某个项目的对齐方式序号 | 属性值 | 描述 |
---|---|---|
1 | auto 默认值 |
继承 align-items 属性值 |
2 | flex-start |
与交叉轴起始线对齐 |
3 | flex-end |
与交叉轴终止线对齐 |
4 | center |
与交叉轴中间线对齐: 居中对齐 |
5 | stretch |
在交叉轴方向上拉伸 |
6 | baseline |
与基线对齐(与内容相关用得极少) |
flex-grow
属性flex-grow
才有意义序号 | 属性值 | 描述 |
---|---|---|
1 | 0 默认值 |
不放大,保持初始值 |
2 | initial |
设置默认值,与0 等效 |
3 | n |
放大因子: 正数 |
flex-shrink
属性flex-shrink
才有意义序号 | 属性值 | 描述 |
---|---|---|
1 | 1 默认值 |
允许项目收缩 |
2 | initial |
设置初始默认值,与 1 等效 |
3 | 0 |
禁止收缩,保持原始尺寸 |
4 | n |
收缩因子: 正数 |
flex-basis
属性min-width/min-height
值覆盖序号 | 属性值 | 描述 |
---|---|---|
1 | auto |
默认值: 项目原来的大小 |
2 | px |
像素 |
3 | % |
百分比 |
优先级: 项目大小 <
flex-basis
<min-width/height
flex
属性flex
属性,可以将以上三个属性进行简化:flex: flex-grow flex-shrink flex-basis
序号 | 属性值 | 描述 |
---|---|---|
1 | 第一个值: 整数 | flex-grow |
2 | 第二个值: 整数 | flex-shrink |
3 | 第三个值: 有效宽度 | flex-basis |
举例:
序号 | 案例 | 描述 |
---|---|---|
1 | flex: 0 1 auto |
默认值: 不放大,可收缩, 初始宽度 |
2 | flex: 1 1 auto |
项目自动放大或收缩适应容器 |
3 | flex: 0 0 100px |
按计算大小填充到容器中 |
序号 | 属性值 | 描述 |
---|---|---|
1 | 第一个值: 整数 | flex-grow |
3 | 第二个值: 有效宽度 | flex-basis |
举例:
案例 | 描述 |
---|---|
flex: 0 180px |
禁止放大,按计算大小填充到容器中 |
序号 | 属性值 | 描述 | ||
---|---|---|---|---|
1 | 整数 | flex-grow |
||
2 | 有效宽度 | flex-basis |
||
3 | 关键字 | `initial | auto | none` |
举例:
序号 | 案例 | 描述 |
---|---|---|
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 |
推荐使用
flex
, 就像推荐使用flex-grow
设置主轴与换行一样
felx-direction
:主轴方向(水平和垂直)flex-wrap
:主轴是否换行显示flex-flow
:主轴方向-是否换行(row nowrap
默认值)(推荐使用)justify-content
:主轴项目对齐方式align-items
:交叉轴项目对齐方式(仅限单行容器)align-content
:交叉轴项目对齐方式(多行容器)align-self
:交叉轴上单个项目对齐方式flex-grow
:项目放大因子(前提条件:容器在主轴上有剩余空间)flex-shrink
:项目收缩因子(前提条件:主轴不换行且项目空间之和大于容器)flex-basis
:单个项目占据的宽度(权重/优先:项目大小width
< flex-basis
< min-width/height
)flex
:项目缩放简写(推荐使用),常用flex:1;
、flex:none