css盒子模型_两小时学会CSS-弹性盒子模型

1c8fe4f8768fb8d925381d0c4cab1a8e.png

弹性盒子模型

布局的传统解决方案,基于盒状模型,依赖display 属性+ position 属性+ float属性。

它对于那些特殊布局非常不方便 垂直居中等。

Flex 简便 、完整 、响应式 实现各种页面布局。

Flex是Flexible Box的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性。设为Flex布局以后,子元素的float、clear和vertical-align属性将失效。

Flex 是 flex-grow、flex-shrink、flex-basis的缩写。

特点:

  1. 元素容器没有足够的空间,无需计算自动设置同意行、同列。
  2. 容易在容器内左、中、右对齐。
  3. 无需修改结构可以可以改变显示顺序。
  4. 容器设置百分比视窗改变大小,子元素自动分配宽度或高度比例。

容器属性:

display :flex / inline-flex

0c31b1750f9ddffce8a29ac092c61d8b.png

flex :box2 不随着子元素变化 100% 撑满屏幕

.

104397fb67b072041181bc10231c7aa3.png

inline-flex :box2 随着 m-1 ... m-5 的宽高自适应

flex - direction 指向主轴方向

 .step1{
        display: flex;
   /* 
        flex-direction:row;  //不设置 默认
        flex-direction:row-reverse;
        flex-direction: column;
        flex-direction: column-reverse;
     */
 }

row :子元素排成一行

020bf3bf53b786a6ce4c3aa1a5420bb3.png

row-reverse :子元素倒序排成一行

7db1d1fe668cabe0d346d1f43dc1f091.png

column:子元素排成一列

44e4018db00dc4b6146efa7ab3dabdcd.png

column-reverse :子元素倒序排成一列

c7f858953af3acf7a82b1307c4366c54.png

flexbox 对齐

justify-content: flex-start | flex-end |center |space -between |space-around

center 、space -between、space-around使用广泛

.

flex-start: 子元素在容器中左对齐 默认

a24c3f57433cd943c0c955482e6ab7e3.png

flex-end: 子元素在容器中右对齐

b18503c4b74e116c092cbfd99a03fe26.png

center: 子元素聚集在中间排列

f82717d0d72d2e204bd3b80f573f890a.png

space-between: 两个元素有间隔排列,撑满容器

a4d78a05fc6392beb8f670f4cba6f1d6.png

space-around: 每个子元素间隔间距左右16px,包括容器

0198bd4e832f541aaf61a121e58c5818.png

flex-wrap 换行

flex-wrap:nowrap | wrap | wrap-reverse;

在一行或一列排不下,是否允许换行

nowrap:(默认显示) 单行显示

wrap: 多行显示,子元素会溢出容器

4b5148011ce1b3a5695292f9b87fbae3.png
.

wrap-reverse:多行 反顺序排列

align-items :交叉轴对齐方式

align-items: flex-start |flex-end| center | basline | stretch

<

flex-start 交叉轴起点对齐,默认左上对齐

flex-end 交叉轴终点对齐 ,左下角对齐

center 交叉轴中点对齐,容器垂直居中对齐

ab6d12d176b4a809be4071d107533086.png

baseline 项目第一行文字的基线对齐

a2e0c089f16b5fbc9367f5dac3a879b6.png

stretch 默认 如果项目未设置高度或设置为auth ,将占满整个容器

efafde950b907d7f641ba384fd6dad4b.png

align-self 属性

align-self: auto|stretch|center|flex-start|flex-end|baseline|initial|inherit;

属性值

| 值 | 描述 | |

| :--------- | :----------------------------------------------------------- | :--- |

| auto | 默认值。元素继承了它的父容器的 align-items 属性。如果没有父容器则为 "stretch"。 | |

| stretch | 元素被拉伸以适应容器。 | |

| center | 元素位于容器的中心。 | |

| flex-start | 元素位于容器的开头。 | |

| flex-end | 元素位于容器的结尾。 | |

| baseline | 元素位于容器的基线上。 | |

| initial | 设置该属性为它的默认值。 | |

| inherit | 从父元素继承该属性。 | |

align-self: center;

<

961af9aa61978f44b946cf3218a9e751.png
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值