(css5)、Flex布局

Flex布局

(一)基本概念

  • 1.1、要设置FlexBox就首先要给父容器设置:display:flex;其主要的意思是给父容器设置伸缩效果,来使得子元素产生相应的效果

  • 1.2、当给父容器设置完display:flex后,父容器默认存在两根轴:水平方向上的主轴和垂直方向上的交叉轴.

  • 主轴的起始位置在左边,交叉轴的起始位置在上边

(二)父容器的属性

对于父元素的属性,一共有6种,下面来详细介绍:

2.1、justify-content:

该属性定义了子元素在主轴上的对齐方式。其一共有6个值:

  • flex-start:(默认值),左对齐
  • flex-end:右对齐
  • center:居中
  • space-around:每个项目两侧的间隔相等
  • space-between:两端对齐,项目之间的间隔都相等
  • space-evenly:每个项目的间隔与项目和容器之间的间隔是相等的
    下面以右对齐为例:
    <style>
        #father{
            margin:0 auto;
            width: 500px;
            height: 300px;
            display: flex;
            /*右对齐*/
            justify-content: flex-end;
            background-color: aliceblue;
        }
    </style>
<body>
    <div id="father">
        <div id="a">A</div>
        <div id="b">B</div>
        <div id="c">C</div>
    </div>
</body>

在这里插入图片描述


2.2、align-items:

该属性定义了子元素在交叉轴上的对齐方式。其一共有5个值:

  • flex-start:交叉轴的起点对齐。
  • flex-end:交叉轴的终点对齐。
  • center:交叉轴的中点对齐。
  • baseline: 项目的第一行文字的基线对齐。
  • stretch(默认值): 如果项目未设置高度或设为auto,将占满整个容器的高度。
    下面以居中对齐为例
align-items:center

在这里插入图片描述


2.3、flex-direction

上文中我们讲到,当我们给父容器设置display:flex后,会默认给父容器生产一个水平方向上的主轴,和垂直方向上的交叉轴。
主轴的起始位置默认在左端,交叉轴的起始位置默认在上端

而flex-direction属性,决定了主轴的方向,其一共有一下四个值:

  • row(默认值):主轴为水平方向,起点在左端。
  • row-reverse:主轴为水平方向,起点在右端。
  • column:主轴为垂直方向,起点在上端。
  • column-reverse:主轴为垂直方向,起点在下端。

2.4、flex-wrap

默认情况下,项目都排在一条线上,无论是否给定宽度,都是不会主动换行的:
在这里插入图片描述

如果需要换行,需要设置:flex-wrap,其一种有四个值:

  • nowrap(默认值):不换行。
  • wrap:换行,第一行在上方。
  • wrap-reverse:换行,第一行在下方。
flex-wrap:wrap

在这里插入图片描述


2.6、align-content

align-content 属性定义了多根轴线的对齐方式,前提是需要设置flex-wrap: wrap,否则不会有效

  • flex-start:与交叉轴的起点对齐。
  • flex-end:与交叉轴的终点对齐。
  • center:与交叉轴的中点对齐。
  • space-between:与交叉轴两端对齐,轴线之间的间隔平均分布。
  • space-around:每根轴线两侧的间隔都相等。
  • stretch(默认值):轴线占满整个交叉轴。

(三)子元素的属性

3.1、order

order 属性定义项目的排列顺序。数值越小,排列越靠前,默认为0,可以是负数。
在这里插入图片描述


3.2、flex-grow
  • flex-grow属性定义了父容器中剩余空间的多少应该分配给项目,也称为扩展规则。默认值为0.
  • 最终的项目的宽度为:自身宽度 + 容器剩余空间分配宽度,flex-grow最大值是1,超过1按照1来扩展
  • 如果所有的兄弟项目都有相同的 flex-grow 系数,那么所有的项目将剩余空间按相同比例分配,否则将根据不同的 flex-grow 定义的比例进行分配。
    在这里插入图片描述

3.3、flex-shrink
  • flex-shrink 属性指定了 flex 元素的收缩规则
  • flex 元素仅在默认宽度之和大于容器的时候才会发生收缩,其收缩的大小是依据 flex-shrink 的值,默认值是1
  • 下面的例子中A元素、B元素、C元素的宽度都是200px,其和大于父容器的宽度500px,但是由于 flex-shrink 都设置为1,将其都收缩在父元素中:
    在这里插入图片描述

3.4、flex-basis

flex-basis 指定了子项在容器主轴方向上的初始大小,优先级高于自身的宽度width

  • 在下面的例子中,A元素width为100px,但是flex-basis为300px,因为flex-basis的优先级高于width,所以最终呈现为300px
    在这里插入图片描述

3.6、align-self

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值