Flex布局常用属性和使用方法

Flex布局是什么

Flex是Flexible Box的缩写,意为”弹性布局”,用来为盒状模型提供最大的灵活性。

Flex是 CSS3 的一种新的布局模式。是一种当页面需要适应不同的屏幕大小以及设备类型时确保元 素拥有恰当的行为的布局方式。

引入弹性盒布局模型的目的是提供一种更加有效的方式来对一个容器中的子元素进行排列、对齐和分配空白 空间。布局的传统解决方案,基于盒状模型,依赖 display属性 + position属性 + float属性。它对于那些特殊布局非常不方便,比如,垂直居中就不容易实现。

如何设置

任何一个容器都可以指定为Flex布局. 在元素的style中设置 - "display: flex". 采用 Flex 布局的元素,称为 Flex 容器(flex container),简称"容器"。它的所有子元素自动成为容器成员,称为 Flex 项目(flex item),简称"项目"。

.box {
  display: flex;
}

.box {
   display: inline-flex;
}

Webkit内核的浏览器,必须加上-webkit前缀。

.box {
   display: -webkit-flex; /* Safari */  display: flex;
}


容器默认存在两根轴:水平的主轴(main axis)垂直的交叉轴(cross axis)。主轴的开始位置(与边框的交叉点)叫做 main start,结束位置叫做 main end;交叉轴的开始位置叫做 cross start,结束位置叫做 cross end

项目默认沿主轴排列。单个项目占据的主轴空间叫做main size,占据的交叉轴空间叫做 cross size

常用的属性

在将元素设置为弹性盒子后, 往往需要配套其他属性一起使用来调整元素位置. 

容器的属性

以下6个属性设置在容器上.

  • flex-direction
  • flex-wrap
  • flex-flow
  • justify-content
  • align-items
  • align-content

flex-direction

通过定义flex容器的主轴方向来决定felx子项在flex容器中的位置。

flex-wrap

控制flex容器是单行或者多行,同时横轴的方向决定了新行堆叠的方向。

flex-flow

设置或检索弹性盒模型对象的子元素排列方式。

justify-content

设置或检索弹性盒子元素在主轴(横轴)方向上的对齐方式。其他类似名称的属性

  • justify-items - 用于控制网格容器中的网格项目在其网格单元格中的水平对齐方式.
    • 用了感觉没啥用.
  • justify-self - 属性将覆盖单个项目上的justify-items。默认情况下,它在网格项目上设置并继承justify-items的值。
  • justify-tracks - 实验性属性

参考文档 - justify-content - CSS: Cascading Style Sheets | MDN

align-items

定义flex子项在flex容器的当前行的侧轴(纵轴)方向上的对齐方式。

align-content

在弹性容器内的各项没有占用交叉轴上所有可用的空间时对齐容器内的各项(垂直)。

项目的属性

以下6个属性设置在项目上

  • flex
  • order
  • flex-grow
  • flex-shrink
  • flex-basis
  • align-self

flex

这个属性需要设置在子元素的style中.用来设置Flex 项目(flex item)在Flex 容器(flex container)的主轴上的比例.  

例子:

每个父元素被设置成了弹性盒子(Flexible Box) - "dispaly: flex". 在子元素中设置的 flex:1 表面每个元素占比50%. 

        <div class="box" style="display: flex; flex-direction: column; ">
            <div style="flex:1; border: 1px solid blue;">
                row1
            </div>
            <div style="flex:1; border: 1px solid blue;">
                row2
            </div>
        </div>

        <div class="box" style="display: flex; flex-direction: column; ">
            <!-- 这里调整了 flex为2 -->
            <div style="flex:2; border: 1px solid blue;">
                row1
            </div>
            <div style="flex:1; border: 1px solid blue;">
                row2
            </div>
        </div>

        <div class="box" style="display: flex; flex-direction: row; ">
            <div style="flex:1; border: 1px solid blue;">
                column1
            </div>
            <div style="flex:1; border: 1px solid blue;">
                column2
            </div>
        </div>

order

设置或检索弹性盒模型对象的子元素出现的順序

flex-grow

设置或检索弹性盒的扩展比率

flex-shrink

设置或检索弹性盒的收缩比率

flex-basis

设置或检索弹性盒伸缩基准值

align-self

定义flex子项单独在侧轴(纵轴)方向上的对齐方式

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值