详解 CSS3中最好用的布局方式——flex弹性布局(看完就会)

简介: 详解 CSS3中最好用的布局方式——flex弹性布局(看完就会)

介绍

 flex布局的优点缺点以及布局原理

  优点

 1.优点在于容易操作,根据flex规则很容易达到某个布局效果。

2.集合了百分比布局和浮动的优点,可以具体设置宽度  

也免于设置以及清除浮动,同样可以达到相同的效果。

  缺点

  1.pc端布局稍差,IE11及以下版本不支持。

  布局原理

 1.通过给父盒子添加flex属性,来控制子盒子的位置和排列方式

2.设置flex属性的容器称为flex父容器,父容器的子元素称为子容器

(flex项目)

当设置flex布局之后,子元素的float,clear,vertical-align属性将失效

学习

由于篇幅原因会演示一部分,想学会就要积极动手

       父容器常见属性

               主轴

          1.flex-direction(设置主轴方向)

                flex布局中分为主轴和侧轴,默认主轴为x轴(水平向右), 侧轴为y轴(水平向下),                         direction属性可以改变主轴的方向,以及更换主轴。

属性值 说明
row 左→右
row-reverse 右→左
column 上→下
column-reverse 下→上

    演示

 <style>

       div{

           /* 没有设置flex属性 */

           width: 300px;

           height: 300px;

           background-color: red;

       }


       div span{

           width: 100px;

           height: 100px;

           background-color: aqua;

       }

   </style>

</head>


<body>

   <div>

       <spanclass="a">1</span>

       <spanclass="b">2</span>

       <spanclass="c">3</span>

   </div>

</body>

image.gif编辑

         可以看出行内元素的特性产生了这种效果  span元素 由内容的多少来决定大小,中间的间隙则是默认的white-space属性产生的回车效果,

                       

<style>
        div {
            /* 给父容器设置flex布局 */
            display: flex;
            width: 800px;
            height: 300px;
            background-color: red;
            /* 默认值为row */
            flex-direction: row;
        }
        div span {
            color: green;
            width: 100px;
            height: 100px;
            background-color: aqua;
        }
    </style>

image.gif

           

设置成flex布局之后,新效果的产生 是因为flex布局会将行内元素转换成行内快元素,标签的大小由设置的宽高决定,而不是内容,元素之间的缝隙也消失了。

    我们修改 direction属性看看效果

        flex-direction: row-reverse; 把默认主轴设置为了  反向行(x)排列

image.gif编辑

   

          2.justify-content 设置主轴上子元素的排列方式

                       使用这个属性之前应当确认好主轴

                       

属性值 说明
flex-start 从左到右或者是从上到下(看主轴)
flex-end 排列到尾部。(跟主轴反转做好区分)
center 在主轴居中对齐
space-around 平分剩余空间
space-between 先两边贴边再平方剩余空间

              演示

                      justify-content: flex-end;

div {
            /* 给父容器设置flex布局 */
            display: flex;
            width: 800px;
            height: 300px;
            background-color: red;
            /* 默认值为row */
            flex-direction: row;
            /* 设置主轴排列方式 */
            justify-content: flex-end;
        }

image.gif

               image.gif编辑

同样是从左往右排列 只不过是会排列到尾部

               justify-content: space-around;

<style>
        div {
            /* 给父容器设置flex布局 */
            display: flex;
            width: 800px;
            height: 300px;
            background-color: red;
            /* 默认值为row */
            flex-direction: row;
            /* 设置主轴排列方式 */
            justify-content: space-around;
        }
        div span {
            color: green;
            width: 100px;
            height: 100px;
            background-color: aqua;
        }
    </style>

image.gif

image.gif编辑

  主轴 x轴剩余空间平均分配

          3.flex-wrap设置子元素是否换行

属性值 说明
nowrap 不换行(默认值)
wrap 换行
wrap-reverse 换行后位置互换
<style>
        div {
            /* 给父容器设置flex布局 */
            display: flex;
            width: 800px;
            height: 300px;
            background-color: red;
            /* 默认值为row */
            flex-direction: row;
            /* 设置主轴排列方式 */
            justify-content: space-around;
        }
        div span {
            color: green;
            width: 100px;
            height: 100px;
            background-color: aqua;
        }
    </style>
</head>
<body>
    <div>
        <span class="a">1</span>
        <span class="b">2</span>
        <span class="c">3</span>
        <span class="d">4</span>
        <span class="e">5</span>
    </div>
</body>

image.gif

image.gif编辑

多添加了两个span标签 设置了分配剩余空间的属性后 父容器撑不下并不会变大,而是会压缩子元素和剩余空间,首先是会分配剩余空间给新的标签,当剩余空间没有了,会压缩子元素的大小。(居中也是)

如果没有设置分配空间 而是给的margin外边距  则不会压缩剩余空间 会直接改变子元素本身的大小。

div {
            /* 给父容器设置flex布局 */
            display: flex;
            width: 600px;
            height: 300px;
            background-color: red;
            /* 默认值为row */
            flex-direction: row;
            /* 设置换行 */
            flex-wrap: wrap;
        }

image.gif

image.gif编辑

剩余空间不够则会直接换行,第一行和第二行中间的距离 可以设置下面学到的align-content:flex-start属性消除。

               flex-flow属性试direction和wrap属性的结合属性 可以直接设置   flex-flow:row wrap;

               侧轴

                       1.align-items设置侧轴子元素的排列方式(单行使用)

属性值 说明
flex-start 从上到下
flex-end 从下到上
center 居中
stretch 拉伸(不能设置高度)

       

<style>
        div {
            /* 给父容器设置flex布局 */
            display: flex;
            width: 600px;
            height: 300px;
            background-color: red;
            /* 默认值为row */
            flex-direction: row;
             /* 主轴水平居中 */
            justify-content: center;
             /* 侧轴垂直居中 */
            align-items: center;
        }
        div span {
            color: green;
            width: 100px;
            height: 100px;
            background-color: aqua;
            margin: 15px;
        }
    </style>
</head>
<body>
    <div>
        <span class="a">1</span>
        <span class="b">2</span>
        <span class="c">3</span>
    </div>
</body>

image.gif

image.gif编辑

这样就实现了水平垂直居中,以往如果用外边距margin:auto,往往只能做到水平居中,还需要搭配其他的属性。

               2.align-content 设置侧轴上的子元素的排列方式(多行)

                       

属性值 说明
flex-start 在侧轴的头部开始排列
flex-end 排列到侧轴的尾部
center 居中
space-around 平分侧轴剩余空间
space-between 子项在侧轴先分布在两头,再平分剩余空间
stretch 行拉伸以占据剩余空间(不能有高度)

       

               

<style>
        div {
            /* 给父容器设置flex布局 */
            display: flex;
            width: 600px;
            height: 300px;
            background-color: red;
            /* 默认值为row */
            flex-direction: row;
         /* 水平平分 */
            justify-content: space-around;
         /* 垂直平分 */
            align-content: space-around;
         /* 换行 */
            flex-wrap: wrap;
        }
        div span {
            color: green;
            width: 100px;
            height: 100px;
            margin: 20px;
            background-color: aqua;
        }
    </style>
</head>
<body>
    <div>
        <span class="a">1</span>
        <span class="b">2</span>
        <span class="c">3</span>
        <span class="a">1</span>
        <span class="b">2</span>
        <span class="c">3</span>
        <span class="b">2</span>
        <span class="c">3</span>
    </div>
</body>

image.gif

image.gif编辑

       子容器常见属性

               1.flex属性

                  flex属性定义子项目在分配剩余空间时,自己占的份数。

                       

<style>
        div {
            /* 给父容器设置flex布局 */
            display: flex;
            width: 600px;
            height: 300px;
            background-color: red;
        /* 先两端对齐再分配剩余空间 */
            justify-content: space-between;
        }
        .b {
            flex: 1;
        }
        div span {
            color: green;
            width: 100px;
            height: 100px;
            border: solid 3px orange;
            background-color: aqua;
        }
    </style>
</head>
<body>
    <div>
        <span class="a">1</span>
        <span class="b">2</span>
        <span class="c">3</span>
    </div>

image.gif

image.gif编辑

   设置的两端补齐在平分, 1和3占在两边  2应该在中间然后 2的两边是相同大小的剩余空间,因为给2设置的flex为1,所以中间2就补满了。

<style>
        div {
            /* 给父容器设置flex布局 */
            display: flex;
            width: 600px;
            height: 300px;
            background-color: red;
        }
        .a {
            flex: 3;
        }
        .b {
            flex: 3;
        }
        .c {
            flex: 1;
        }
        div span {
            color: green;
            width: 100px;
            height: 100px;
            border: solid 3px orange;
            background-color: aqua;
        }
    </style>

image.gif

image.gif编辑

分成七份,1和2各占三份,3占一份。

           2.align-self控制单个子元素侧轴的排列方式

               设置单个子元素的排列方式会覆盖align-items

               

<style>
        div {
            /* 给父容器设置flex布局 */
            display: flex;
            width: 600px;
            height: 300px;
            background-color: red;
            align-items: flex-end;
        }
        .a {
            flex: 3;
            align-self: flex-start;
        }
        .b {
            flex: 3;
        }
        .c {
            flex: 1;
        }
        div span {
            color: green;
            width: 100px;
            height: 100px;
            border: solid 3px orange;
            background-color: aqua;
        }
    </style>

image.gif

image.gif编辑

给第一个span单独设置了start另外两个是end

         3.order修改标签的排列顺序

               

<style>
        div {
            /* 给父容器设置flex布局 */
            display: flex;
            width: 600px;
            height: 300px;
            background-color: red;
            align-items: flex-end;
        }
        .a {
            flex: 3;
            align-self: flex-start;
        }
        .b {
            flex: 3;
        }
        .c {
            flex: 1;
            order: -1;
        }
        div span {
            color: green;
            width: 100px;
            height: 100px;
            border: solid 3px orange;
            background-color: aqua;
        }
    </style>

image.gif

               image.gif编辑

order默认为0,第三个span标签order设置为-1,变成了最小的,所以变成了第一个,此属性可以帮助我们不修改标签的位置来改变页面元素。

总结

               

常见父项属性

    1. flex-direction:设置主轴的方向
    2. justify-content:设置主轴上的子元素排列方式
    3. flex-wrap:设置子元素是否换行
    4. align-content:设置侧轴上的子元素的排列方式(多行)
    5. align-items:设置侧轴上的子元素排列方式(单行)
    6. flex-flow:复合属性,相当于同时设置了 flex-direction 和 flex-wrap

    flex布局子项常见属性

      1. flex 子项目占的份数
      2. align-self 控制子项自己在侧轴的排列方式
      3. order 属性定义子项的排列顺序(前后顺序)
      相关文章
      flex布局属性简介
      flex布局属性简介
      |
      8天前
      |
      弹性计算 前端开发 容器
      【前端web入门第六天】02 flex布局
      Flex布局是一种现代CSS布局模式,通过给父元素设置`display: flex`,其子元素可自动挤压或拉伸。它包含弹性容器和弹性盒子,主轴默认为水平方向,侧轴为垂直方向。主轴对齐方式由`justify-content`属性控制,侧轴对齐方式包括`align-items`(针对所有子元素)和`align-self`(针对单个子元素)。修改主轴方向使用`flex-direction`属性,`flex`属性用于控制子元素在主轴上的伸缩比例。此外,`flex-wrap`属性允许子元素换行,而`align-content`属性则定义多行对齐方式。
      |
      1月前
      |
      前端开发
      FLex布局详解
      Flex布局通过`flex-direction`定义主轴方向,包括横向`row`、反向横向`row-reverse`、纵向`column`及反向纵向`column-reverse`。`justify-content`控制主轴上子元素的排列,如起始端`flex-start`、末端`flex-end`、居中`center`、等间距`space-around`或两端对齐`space-between`。在Y轴上设置这些同样有效。`flex-wrap: wrap`使子元素在需要时换行。`align-items: center`实现侧轴(交叉轴)上的居中对齐
      46 1
      FLex布局详解
      |
      22天前
      |
      前端开发 安全 容器
      CSS如何优雅实现卡片多行排列布局?
      【8月更文挑战第24天】CSS如何优雅实现卡片多行排列布局?
      37 3
      |
      22天前
      |
      前端开发 开发者 容器
      探索现代Web开发中的CSS Grid布局技术
      【8月更文挑战第29天】在数字时代的浪潮中,网页设计不断进化以适应日新月异的用户需求。CSS Grid布局技术作为一项革新性的前端工具,为设计师和开发者提供了前所未有的布局能力。本文旨在通过深入浅出的方式介绍CSS Grid的核心概念、基本用法以及在实际项目中的应用,帮助读者快速掌握这一强大的网页布局工具。
      40 3
      |
      22天前
      |
      JavaScript
      Vue3弹性布局(Flex)
      这是一个基于 Vue 的弹性布局组件库,提供了丰富的参数配置,如宽度、方向、换行等,支持自定义对齐方式和间隙设置。在线预览展示了不同布局效果,包括单选、按钮和滑动输入条等组件的使用示例。
      Vue3弹性布局(Flex)
      |
      26天前
      |
      前端开发 开发者 容器
      【Web布局的革命】探索CSS Grid栅格系统,打造未来网页设计!
      【8月更文挑战第25天】在网页设计领域,布局至关重要。传统的布局方法难以满足复杂需求,CSS Grid 栅格系统因此诞生。它是一种二维布局模式,能直接控制行和列,简化复杂网格的设计。通过定义 `display: grid;` 创建网格容器,并利用 `grid-template-columns` 和 `grid-template-rows` 设置行列尺寸,轻松实现响应式布局。此外,CSS Grid 支持高级功能,如网格区域划分和对齐设置,极大提升了布局的灵活性和创意空间。随着浏览器兼容性的增强,CSS Grid 必将成为未来网页设计的关键技术之一。
      49 1
      |
      1月前
      |
      前端开发 JavaScript Serverless
      揭秘CSS布局神器:vw/vh、rem、%与px大PK,掌握它们,让你的网页设计秒变高大上,面试难题迎刃而解!
      【8月更文挑战第4天】在Web开发中,合理选择CSS单位对响应式布局至关重要。本文探索viewport单位(vw/vh)、rem、百分比(%)及像素(px)的基础知识与应用场景。通过代码示例,展示如何运用这些单位实现全屏布局、尺寸比例调整、灵活的元素大小及固定尺寸。最后,模拟面试题,介绍如何仅用CSS实现一个元素的高度为其宽度两倍且响应视口变化的方法。
      141 8
      |
      29天前
      |
      前端开发 容器
      掌握弹性盒子布局(Flex):打造灵活的网页布局
      掌握弹性盒子布局(Flex):打造灵活的网页布局
      |
      1月前
      |
      容器