一文搞懂 Flex 属性,轻松掌握弹性布局排列与对齐

在前端开发中,弹性布局是一种强大且实用的布局模式,它能够帮助开发者更轻松地创建灵活、响应式的页面布局。

Flex属性

flex 属性是一个用于弹性布局(Flexible Box Layout,简称 Flexbox)的复合属性,它是 flex-growflex-shrinkflex-basis这三个属性的缩写,用于定义弹性项目(flex item)在弹性容器(flex container)内如何分配空间。

1. flex-grow

  • 作用 :定义弹性项目的放大比例。当弹性容器的剩余空间为正值时,该属性会根据各个弹性项目的 flex-grow 值来分配这些剩余空间。
  • 取值 :一个非负的数值,默认值为 0,表示不放大。

2. flex-shrink

  • 作用 :定义弹性项目的缩小比例。当弹性容器的空间不足时,该属性会根据各个弹性项目的 flex-shrink 值来缩小这些项目。
  • 取值 :一个非负的数值,默认值为 1,表示会缩小。

3. flex-basis

  • 作用:定义弹性项目在分配剩余空间之前的初始大小。
  • 取值 :可以是一个长度值(如 pxem 等),也可以是一个百分比,还可以是 auto(默认值),表示根据项目的内容自动确定大小。

4. flex 属性

  • 作用 :作为 flex-growflex-shrinkflex-basis 的缩写,用于一次性设置这三个属性。

  • 取值

    • 单值语法 :可以是一个无单位的数值(相当于 flex-grow),也可以是一个长度值或百分比(相当于 flex-basis),还可以是 noneautoinitial
    • 双值语法 :第一个值必须是无单位的数值(flex-grow),第二个值可以是无单位的数值(flex-shrink)或长度值 / 百分比(flex-basis)。
    • 三值语法 :依次为 flex-growflex-shrinkflex-basis

使用flex属性进行弹性布局

1. 创建弹性容器

要使用弹性布局,首先需要将一个元素设置为弹性容器。可以通过将该元素的 display 属性设置为 flexinline-flex 来实现。

  • display: flex:将元素显示为块级弹性容器。
  • display: inline-flex:将元素显示为内联级弹性容器。

2. 添加弹性项目

在弹性容器内添加子元素,这些子元素将成为弹性项目。

3. 使用 flex 属性控制弹性项目的大小和伸缩性

flex 属性是 flex-growflex-shrinkflex-basis 的缩写,通过设置 flex 属性可以控制弹性项目如何分配空间。

常见的 flex 属性设置示例
  • flex: 1:表示弹性项目会平均分配弹性容器的剩余空间。
html 复制代码
        .flex-container {
            display: flex;
            background-color: lightgray;
            width: 500px;
        }
        .flex-item {
            background-color: lightblue;
            margin: 10px;
            padding: 20px;
            font-size: 30px;
            flex: 1;
        }

在这个示例中,三个弹性项目会平均分配容器的剩余空间,因为它们的 flex 值都为 1

  • flex: 2 1 300px:表示弹性项目的 flex-grow2flex-shrink1flex-basis300px
html 复制代码
        .flex-container {
            display: flex;
            background-color: lightgray;
            width: 800px;
        }
        .flex-item {
            background-color: lightblue;
            margin: 10px;
            padding: 20px;
            font-size: 30px;
        }
        .item1 {
            flex: 2 1 300px;
        }
        .item2 {
            flex: 1 1 200px;
        }

在这个示例中,item1 的初始大小为 300px,并且在有剩余空间时会以 2 倍的比例进行放大;item2 的初始大小为 200px,放大比例为 1

控制弹性项目的排列方向和对齐方式

容器属性

1. flex-direction
  • 作用:定义弹性容器内弹性项目的排列方向。

  • 取值

    • row:默认值,弹性项目沿水平方向从左到右排列。
    • row-reverse:弹性项目沿水平方向从右到左排列。
    • column:弹性项目沿垂直方向从上到下排列。
    • column-reverse:弹性项目沿垂直方向从下到上排列。
2. flex-wrap
  • 作用:定义弹性项目是否换行显示。

  • 取值

    • nowrap:默认值,弹性项目不换行,会缩小以适应容器宽度。
    • wrap:弹性项目换行显示,当一行放不下时会自动换到下一行。
    • wrap-reverse:弹性项目换行显示,但换行方向与 wrap 相反。
3. flex-flow
  • 作用flex-directionflex-wrap 的缩写属性,同时设置弹性项目的排列方向和是否换行。
  • 取值 :先指定 flex-direction 的值,再指定 flex-wrap 的值,中间用空格分隔。
css 复制代码
        .flex-container {
            display: flex;
            width: 300px;
            height: 200px;
            margin: 20px;
            background-color: lightgray;
        }

        .flex-item {
            width: 100px;
            height: 50px;
            background-color: lightblue;
            display: flex;
            justify-content: center;
            align-items: center;
        }

        .row-nowrap {
            flex-flow: row nowrap;
        }

        .row-wrap {
            flex-flow: row wrap;
        }

        .column-wrap {
            flex-flow: column wrap;
            width: 200px;
            height: 300px;
        }
4. justify-content
  • 作用 :定义弹性项目在主轴(由 flex-direction 决定)上的对齐方式。

  • 取值

    • flex-start:默认值,弹性项目在主轴起点对齐。
    • flex-end:弹性项目在主轴终点对齐。
    • center:弹性项目在主轴上居中对齐。
    • space-between:弹性项目两端对齐,项目之间的间隔相等。
    • space-around:每个弹性项目两侧的间隔相等,项目之间的间隔比项目与容器边缘的间隔大一倍。
    • space-evenly:弹性项目之间以及项目与容器边缘的间隔都相等。
5. align-items
  • 作用:定义弹性项目在交叉轴(与主轴垂直)上的对齐方式。

  • 取值

    • stretch:默认值,弹性项目在交叉轴方向上拉伸以填充容器。
    • flex-start:弹性项目在交叉轴起点对齐。
    • flex-end:弹性项目在交叉轴终点对齐。
    • center:弹性项目在交叉轴上居中对齐。
    • baseline:弹性项目的第一行文字的基线对齐。
6. align-content
  • 作用 :定义多行弹性项目在交叉轴上的对齐方式,当 flex-wrapwrapwrap-reverse 时生效。

  • 取值

    • stretch:默认值,多行弹性项目在交叉轴方向上拉伸以填充容器。
    • flex-start:多行弹性项目在交叉轴起点对齐。
    • flex-end:多行弹性项目在交叉轴终点对齐。
    • center:多行弹性项目在交叉轴上居中对齐。
    • space-between:多行弹性项目两端对齐,行与行之间的间隔相等。
    • space-around:每行弹性项目两侧的间隔相等,行与行之间的间隔比行与容器边缘的间隔大一倍。

项目属性

1. align-self
  • 作用 :用于单独设置某个弹性项目在交叉轴上的对齐方式,会覆盖容器的 align-items 设置。
  • 取值 :与 align-items 相同,包括 auto(默认值,继承容器的 align-items 设置)、stretchflex-startflex-endcenterbaseline
2. order
  • 作用:定义弹性项目的排列顺序,数值越小越靠前。
  • 取值 :整数,默认值为 0
相关推荐
美酒没故事°22 分钟前
纯css实现蜂窝效果
前端·javascript·css
GISer_Jing44 分钟前
React useState 的同步/异步行为及设计原理解析
前端·javascript·react.js
mini榴莲炸弹1 小时前
什么是SparkONYarn模式?
前端·javascript·ajax
能来帮帮蒟蒻吗1 小时前
VUE3 -综合实践(Mock+Axios+ElementPlus)
前端·javascript·vue.js·笔记·学习·ajax·typescript
酷爱码1 小时前
HTML5中的Microdata与历史记录管理详解
前端·html
开开心心就好1 小时前
高效全能PDF工具,支持OCR识别
java·前端·python·pdf·ocr·maven·jetty
郭尘帅6663 小时前
vue3基础学习(上) [简单标签] (vscode)
前端·vue.js·学习
njsgcs3 小时前
opencascade.js stp vite webpack 调试笔记
开发语言·前端·javascript
T0uken4 小时前
【前端】:单 HTML 去除 Word 批注
前端·html·word
st紫月5 小时前
用vue和go实现登录加密
前端·vue.js·golang