CSS中flex的用法( 学习笔记 )

flex( 弹性盒、伸缩盒 )


flex 的介绍
  • flex是CSS中的又一种布局手段,它主要用来代替浮动来完成页面的布局
  • flex可以使元素具有弹性,让元素可以随页面的大小的改变而改变

弹性容器

  1. 要使用弹性盒,必须先将一个元素设置为弹性容器
  2. 我们通过 display 来设置弹性容器
  3. display:flex 设置为块级弹性容器(常用
  4. deplay:inline-flex 设置为行内的弹性容器

弹性元素

  1. 弹性容器的直接子元素( 非后代 )是弹性元素(弹性项)
  2. 弹性元素可以同时是弹性容器

弹性容器的属性
一、flex-direction
  • flex-direction 指定容器中弹性元素的排列方式
  • 可选值:
  1. row 默认值,弹性元素在容器中水平排列(从左向右) row-reverse
  2. 弹性元素在容器中反向水平排列(从右向左)
  3. column 弹性元素纵向排列(从上向下)
  4. column-reverse 弹性元素纵向排列(从下向上)
  • 主轴:弹性元素的排列方向称为主轴
  • 侧轴:与主轴垂直方向的称为侧轴

二、flex-grow(弹性元素的增长系数)
  • flex-grow 指定弹性元素的伸展的系数
  • 当父元素有多余空间的时候,子元素如何伸展
  • 父元素的剩余空间,会按照比例进行分配
  • 例子:flex-grow: 1; 默认值0时不伸展

三、flex-shrink(弹性元素的缩减系数)
  • flex-shrink 指定弹性元素的收缩系数
  • 当父元素中的空间不足以容纳所有子元素时,对子元素进行收缩

四、flex-wrap
  • 设置弹性元素是否在弹性容器里自动换行
  • 可选值: nowrap 默认值,元素不会自动换行
  • wrap 元素沿着辅轴方向自动换行
  • wrap-reverse 元素沿着辅轴反方向换行
  • flex-flow:wrap 和 direction 的简写属性

五、justify-conten
  • 分配主轴上的空白空间(主轴上的元素如何排列)
  • 可选值:
  1. flex-start 元素沿着主轴起边排列
  2. flex-end 元素沿着主轴终边排列
  3. center 元素居中排列
  4. space-around 空白分布到元素两侧
  5. space-between 空白均匀分布到元素间
  6. space-evenly 空白分布到元素的单侧
  • 注意:有 justify 的代表元素在主轴上的排列

六、align-items
  • 元素在辅轴上如何对齐
  • 元素与元素间的关系
  • 可选值: stretch 默认值,将元素的长度设置为相同的值
  • flex-start 元素不会拉伸,沿着辅轴起边对齐
  • flex-end 元素不会拉伸,沿着辅轴终边对齐
  • center 居中对齐
  • baseline 基线对齐

七、align- content
  • 分配辅轴上的空白空间
  • 可选值:
  1. flex-start 元素沿着主轴起边排列
  2. flex-end 元素沿着主轴终边排列
  3. center 元素居中排列
  4. space-around 空白分布到元素两侧
  5. space-between 空白均匀分布到元素间
  6. space-evenly 空白分布到元素的单侧
  • 注意:有 align 的代表元素在辅轴上的排列

八、align-self
  • 用来覆盖弹性元素上的align-items

九、flex-basis
  • 指定的是元素在主轴上的基础长度
  • 如果主轴是横向的 则 该值指定的就是元素的高度
  • 如果主轴是纵向的 则 该值指定的就是元素的宽度
  • 默认值是 auto ,表示参考元素自身的高度或宽度
  • 如果传递了一个具体的数值,则以该值为准

十、order
  • 设置弹性元素的排列顺序
  • 例子:order: 1; 弹性元素排第一个

总结:

  • flex可以设置弹性元素所有的三个样式:
  • flex 增长 缩减 基础;
  • 可选值:
  1. initial “flex: 0 1 auto;”
  2. auto “flex: 1 1 auto;”
  3. none "flex: 0 0 auto"弹性元素没有弹性

w3school导航栏实例:

    <ul class="nav">
        <li><a href="#">HTML/CSS</a></li>
        <li><a href="#">Browser Side</a></li>
        <li><a href="#">Server Side</a></li>
        <li><a href="#">Programming</a></li>
        <li><a href="#">XML</a></li>
        <li><a href="#">Web Building</a></li>
        <li><a href="#">Reference</a></li>
    </ul>
    .nav{
        width: 1210px;
        height: 48px;
        line-height: 48px;
        background-color: #E8E7E3;
        margin: 50px auto;
        margin-top: 100px;
        list-style: none;
        display: flex;
        padding-left: 0;
    }
    .nav li{
        flex-grow: 1;
    }
    .nav a{
        display: block;
        color: #808080;
        text-decoration: none;
        font-size: 18px;
        text-align: center
    }
    .nav a:hover{
        color: #fff;
        background-color: #636363;
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值