CSS:弹性盒子模型详解(用法 + 例子 + 效果)

目录

  • 弹性盒子模型
    • flex-direction 排列方式 主轴方向
    • 换行
    • 排序
    • 控制子元素缩放比例
      • 缩放是如何实现的?
    • 控制子元素的对其方式
      • justify-content 横向 对齐方式
      • align-items 纵向 对齐方式
    • align-content 多行 对齐方式

弹性盒子模型

flex-direction 排列方式 主轴方向

flex-direction: row; 横向布局,默认从左向右。
flex-direction: row-reverse; 横向布局,从右向左。
flex-direction: column; 纵向布局,从上到下。
flex-direction: column-reverse; 纵向布局,从下到上。

.top{
    width:800px;
    background: yellow;
    display:flex;
    flex-direction: row-reverse;  
}

CSS:弹性盒子模型详解(用法 + 例子 + 效果)_第1张图片

换行

flex-wrap: wrap; 换行
flex-wrap: nowrap; 不换行

排序

给子级加上 order: 编号
值越小越考前,值越大越向后排。

.top{
    width:800px;
    background: yellow;
    display:flex;
    flex-direction: row;  
}

.bottom{
    width:800px;
    height:200px;
    background:pink;
}

.left{
    width:200px;
    height:100px;
    background:orange;
    float:left;
    order:1;
}
.middle{
    width:200px;
    height:100px;
    background:blue;
    float:left;
    order:3;
}
.right{
    width:200px;
    height:100px;
    background: purple;
    float:left;
    order:2;
}

CSS:弹性盒子模型详解(用法 + 例子 + 效果)_第2张图片

控制子元素缩放比例

作用于子级元素。
flex-shrink: 压缩因子。
flex-grow: 拉伸因子。
flex-grow: 基准因子,一般用宽度代替。

.top{
    width:800px;
    background: yellow;
    display:flex;
    flex-direction: row;  
}

.bottom{
    width:800px;
    height:200px;
    background:pink;
}

.left{
    width:200px;
    height:100px;
    background:orange;
    flex-grow: 8;
}
.middle{
    width:200px;
    height:100px;
    background:blue;
    flex-grow:5;
}
.right{
    width:200px;
    height:100px;
    background: purple;
    flex-grow:1;
}

三个比例的拉伸效果:
CSS:弹性盒子模型详解(用法 + 例子 + 效果)_第3张图片
CSS:弹性盒子模型详解(用法 + 例子 + 效果)_第4张图片
CSS:弹性盒子模型详解(用法 + 例子 + 效果)_第5张图片

缩放是如何实现的?

拉伸:把所有flex-gorw求和,在把未占满的位置分为总和个份数,根据每个子集的比例分给子集。
缩小:根据子集宽度按比例比例自动缩小。

控制子元素的对其方式

justify-content 横向 对齐方式

其实是和主轴方向有关系,不一定是横向的,这里用横向举例展示。
justify-content: flex-start; 默认左对其
CSS:弹性盒子模型详解(用法 + 例子 + 效果)_第6张图片
justify-content: flex-end; 右
CSS:弹性盒子模型详解(用法 + 例子 + 效果)_第7张图片
justify-content: center; 中间
CSS:弹性盒子模型详解(用法 + 例子 + 效果)_第8张图片
justify-content: space-between; 空白放中间
CSS:弹性盒子模型详解(用法 + 例子 + 效果)_第9张图片
justify-content: space-around; 空白放周围
CSS:弹性盒子模型详解(用法 + 例子 + 效果)_第10张图片
justify-content: space-evenly; 空白均匀分布
CSS:弹性盒子模型详解(用法 + 例子 + 效果)_第11张图片

align-items 纵向 对齐方式

align-items: flex-start; 默认顶端对齐
CSS:弹性盒子模型详解(用法 + 例子 + 效果)_第12张图片
align-items: flex-end; 底端对齐
CSS:弹性盒子模型详解(用法 + 例子 + 效果)_第13张图片
align-items: center; 居中对齐
CSS:弹性盒子模型详解(用法 + 例子 + 效果)_第14张图片
align-items: baseline; 首行底端对齐
CSS:弹性盒子模型详解(用法 + 例子 + 效果)_第15张图片

align-content 多行 对齐方式

align-content: flex-start; 所有行都在顶端
我们先给给父级加上高度,好用来展示效果。
CSS:弹性盒子模型详解(用法 + 例子 + 效果)_第16张图片
align-content: flex-end; 底部
CSS:弹性盒子模型详解(用法 + 例子 + 效果)_第17张图片
align-content: center; 中间
CSS:弹性盒子模型详解(用法 + 例子 + 效果)_第18张图片
align-content: space-betwween; 空白放中间
CSS:弹性盒子模型详解(用法 + 例子 + 效果)_第19张图片
align-content: space-around; 空白放周围
CSS:弹性盒子模型详解(用法 + 例子 + 效果)_第20张图片
align-content: space-evenly; 空白均匀分布
CSS:弹性盒子模型详解(用法 + 例子 + 效果)_第21张图片

你可能感兴趣的:(CSS,css,前端,盒子模型)