CSS的flex布局

传统盒模型布局方式

CSS常见的布局方式如下图所示。传统布局方式就是通过盒子模型,使用display+postion+float属性完成布局。详见参考文章

请添加图片描述

文档流布局

display布局方式,按照文档的顺序一个一个的显示出来,块元素独占一行,行内元素共享一行

浮动布局

浮动方式布局就是使用 float 属性,使元素脱离文档流,浮动起来。

定位布局

通过 position 属性来进行定位

flex布局

在这里插入图片描述

2009年,W3C 提出了一种新的方案----Flex 布局,可以简便、完整、响应式地实现各种页面布局。目前,它已经得到了所有浏览器的支持,这意味着,现在就能很安全地使用这项功能。
Flex 是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性。
Flex 是一种新型的布局方式,使用该布局方式可以实现几乎所有你想要的效果。但是要注意其浏览器的兼容性,flex 只支持 ie 10+,所有还是要根据你的项目情况使用

在这里插入图片描述

使用flex布局很简单,我们只需要将display设置为flex即可,记得 Webkit 内核的浏览器,必须加上 -webkit 前缀。重要的是设为flex布局以后,子元素的float clear vertical-align属性都会失效

   .ele{
       display: -webkit-flex;
       display: flex;
       display: inline-flex;
       display: -webkit-inline-flex;
   }

在 flex 中,最核心的概念就是容器和轴,所有的属性都是围绕容器和轴设置的。其中,容器分为父容器和子容器。轴分为主轴和交叉轴(主轴默认为水平方向,方向向右,交叉轴为主轴顺时针旋转 90°)。

在这里插入图片描述
在使用flex的元素中,默认存在两根轴,水平的主轴main axis和垂直的交叉轴 cross axis 主轴开始的位置称为 main start 主轴结束的位置称为main end
同理,交叉轴开始的位置称为cross start 交叉轴结束的位置称为cross end
在使用flex的子元素中,占据的主轴空间叫做main size 占据的交叉轴空间叫做cross size

父容器属性

  • flex-direction 主轴的方向

flex-direction 属性决定主轴的方向(主轴的方向不一定是水平的,这个属性就是设置主轴的方向,主轴默认是水平方向,从左至右,如果主轴方向设置完毕,那么交叉轴就不需要设置,交叉轴永远是主轴顺时针旋转 90°)。

.ele {
  flex-direction: row;                // 默认值,主轴为水平方向,起点在左端。
  flex-direction: row-reverse;        // 主轴为水平方向,起点在右端。
  flex-direction: column;             // 主轴为垂直方向,起点在上。
  flex-direction: column-reverse;     // 主轴为垂直方向,起点在下。
}

在这里插入图片描述

  • flex-wrap 超出父容器子容器的排列方式

flex-wrap 属性决定子容器如果在一条轴线排不下时,如何换行。

.ele {
 flex-wrap: nowrap;          // 默认,不换行
 flex-wrap: wrap;            // 换行,第一行在上方。
 flex-wrap: wrap-reverse     // 换行,第一行在下方。

在这里插入图片描述

  • justify-content 子容器在主轴的排列方向

justify-content 属性定义了子容器在主轴上的对齐方式。

.ele{
    justify-content: flex-start;      // 默认,左对齐
    justify-content: flex-end;        // 右对齐
    justify-content: center;          // 居中
    justify-content: space-between;   // 两端对齐,项目之间的间隔都相等。
    justify-content: space-around;    // 每个项目两侧的间隔相等。所以,项目之间的间隔比项目与边框的间隔大一倍。

}

在这里插入图片描述

  • flex-flow 前两个属性的简写形式

flex-flow 属性是 flex-direction 属性和 flex-wrap 属性的简写形式,默认值为 row nowrap。

.ele {
  flex-flow: <flex-direction> || <flex-wrap>;
}
  • align-items 子容器在交叉轴的排列方式

align-items属性定义子容器在交叉轴上如何对齐。
具体的对齐方式与交叉轴的方向有关,下面假设交叉轴从上到下。

.ele{
    align-items: flex-start;    // 交叉轴的起点对齐。
    align-items: flex-end;      // 交叉轴的终点对齐。
    align-items: center;        // 交叉轴的中点对齐。
    align-items: baseline;      // 项目的第一行文字的基线对齐。
    align-items: stretch;       // 默认,如果项目未设置高度或设为auto,将占满整个容器的高度。
}

在这里插入图片描述

  • align-content 多根轴线的对齐方式

align-content 属性定义了多根轴线的对齐方式。如果项目只有一根轴线,该属性不起作用

.ele{
    align-content: flex-start;   // 与交叉轴的起点对齐
    align-content: flex-end;     // 与交叉轴的终点对齐。
    align-content: center;       // 与交叉轴的中点对齐。
    align-content: space-between;// 与交叉轴两端对齐,轴线之间的间隔平均分布。
    align-content: space-around; // 每根轴线两侧的间隔都相等。所以,轴线之间的间隔比轴线与边框的间隔大一倍。
    align-content: stretch;     // 默认 轴线占满整个交叉轴。
}

在这里插入图片描述

子容器属性

  • order:子容器的排列顺序

order 属性定义项目的排列顺序。数值越小,排列越靠前,默认为 0

.ele{
   order: num; 
}

在这里插入图片描述

  • flex-grow:子容器剩余空间的拉伸比例

flex-grow 属性定义子容器的伸缩比例。按照该比例给子容器分配空间。

.ele{
    flex-grow: <number>; /* default 0 */
}

在这里插入图片描述

  • flex-shrink:子容器超出空间的压缩比例

flex-shrink 属性定义了子容器弹性收缩的比例。如图,超出的部分按 1:2 的比例从给子容器中减去。此属性要生效,父容器的 flex-wrap 属性要设置为 nowrap

.ele{
    flex-shrink: <number>; /* default 0 */
}

在这里插入图片描述

  • flex-basis:子容器在不伸缩情况下的原始尺寸

flex-basis 属性定义了子容器在不伸缩情况下的原始尺寸,主轴为横向时代表宽度,主轴为纵向时代表高度。

.ele{
    flex-basis: <length> | auto; /* default auto */
}

在这里插入图片描述

  • flex:子元素的 flex 属性是 flex-grow,flex-shrink 和 flex-basis 的简写

子元素的 flex 属性是 flex-grow,flex-shrink 和 flex-basis 的简写,默认值为 0 1 auto。后两个属性可选。

  • align-self

子容器的 align-self 属性允许单个项目有与其他项目不一样的对齐方式,可覆盖父容器 align-items 属性。默认值为 auto,表示继承父元素的 align-items属性,如果没有父元素,则等同于 stretch。

在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

清辞-

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值