【前端】CSS-flexbox弹性盒模型布局

目录

一、前言

CSS弹性盒子(Flexbox)是一种强大而灵活的布局模型,能够简化我们对网页布局的控制,并使页面在不同设备上的适应性更强。本文将介绍CSS弹性盒子的基本概念、属性和使用方法,帮助你更好地掌握弹性盒子布局。

二、flexbox简介

CSS弹性盒子是一种用于网页布局的模型,旨在提供一种更简单、更灵活的方法来排列、对齐和分布元素。使用弹性盒子布局,我们可以轻松地调整和修改布局,适应不同设备和屏幕尺寸,实现自适应的网页布局。

三、属性

关于flex常用的属性,我们可以划分为容器属性和容器成员属性

1、容器属性

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

2、容器成员属性

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

四、容器属性的作用

1、flex-direction

①、定义

决定主轴的方向(即项目的排列方向)

②、语句

html 复制代码
.container {
    flex-direction: row | row-reverse | column | column-reverse;
}

1)、属性值

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

③、代码示例

1)、flex-direction: row

html 复制代码
<div class="container">
  <div class="item"></div>
  <div class="item"></div>
  <div class="item"></div>
</div>

.container {
  display: flex;
  flex-direction: row;
}

.item {
  width: 100px;
  height: 100px;
  background-color: #f0f0f0;
  margin: 10px;
}

2)、flex-direction: row-reverse

html 复制代码
<div class="container">
  <div class="item"></div>
  <div class="item"></div>
  <div class="item"></div>
</div>

.container {
  display: flex;
  flex-direction: row-reverse;
}

.item {
  width: 100px;
  height: 100px;
  background-color: #f0f0f0;
  margin: 10px;
}

3)、flex-direction: column

html 复制代码
<div class="container">
  <div class="item"></div>
  <div class="item"></div>
  <div class="item"></div>
</div>

.container {
  display: flex;
  flex-direction: column;
}

.item {
  width: 100px;
  height: 100px;
  background-color: #f0f0f0;
  margin: 10px;
}

4)、flex-direction: column-reverse

html 复制代码
<div class="container">
  <div class="item"></div>
  <div class="item"></div>
  <div class="item"></div>
</div>

.container {
  display: flex;
  flex-direction: column-reverse;
}

.item {
  width: 100px;
  height: 100px;
  background-color: #f0f0f0;
  margin: 10px;
}

2、flex-wrap

①、定义

弹性元素永远沿主轴排列,那么如果主轴排不下,通过flex-wrap决定容器内项目是否可换行

②、语句

html 复制代码
.container {
    flex-wrap: nowrap | wrap | wrap-reverse;
}

1)、属性值

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

默认情况是不换行,但这里也不会任由元素直接移除容器,会涉及到元素的弹性伸缩

③、代码示例

1)、flex-wrap:nowrap

html 复制代码
<div class="content1">
   <div class="red">1</div>
   <div class="green">2</div>
   <div class="blue">3</div>
</div>

.content1 {
    color: #fff;
    font: 100 24px/100px sans-serif;
    height: 150px;
    width: 897px;
    text-align: center;
}

.content1 div {
     height: 50%;
     width: 300px;
}

.content1 {
    display: flex;
    flex-wrap: nowrap;
}

2)、flex-wrap:wrap

html 复制代码
<div class="content">
   <div class="red">1</div>
   <div class="green">2</div>
   <div class="blue">3</div>
</div>

.content {
    color: #fff;
    font: 100 24px/100px sans-serif;
    height: 150px;
    width: 897px;
    text-align: center;
}

.content div {
     height: 50%;
     width: 300px;
}

.content {
    display: flex;
    flex-wrap: wrap;
}

3)、flex-wrap:wrap-reverse

html 复制代码
<div class="content2">
   <div class="red">1</div>
   <div class="green">2</div>
   <div class="blue">3</div>
</div>

.content2 {
    color: #fff;
    font: 100 24px/100px sans-serif;
    height: 150px;
    width: 897px;
    text-align: center;
}

.content2 div {
     height: 50%;
     width: 300px;
}

.content2 {
    display: flex;
    flex-wrap: wrap-reverse;
}

3、flex-flow

①、定义

是flex-direction属性和flex-wrap属性的简写形式,默认值为row nowrap

②、语句

html 复制代码
.box {
  flex-flow: <flex-direction> || <flex-wrap>;
}

③、代码示例

html 复制代码
element {
  flex-flow: column-reverse wrap;
}

4、justify-content

①、定义

定义了项目在主轴上的对齐方式

②、语句

html 复制代码
.box {
    justify-content: flex-start | flex-end | center | space-between | space-around;
}

1)、属性值

  • flex-start(默认值):左对齐
  • flex-end:右对齐
  • center:居中
  • spac-between:两端对齐,项目之间的间隔相等
  • space-around:两个项目两侧间隔相等

③、代码示例

1)、justify-content

html 复制代码
    <div class="container">
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
    </div>
    .container {
       display: flex;
       justify-content: flex-start;
     }

     .item {
       width: 100px;
       height: 100px;
       background-color: #e18181;
       margin: 10px;
    }

2)、justify-content:flex-end

html 复制代码
    <div class="container">
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
    </div>
    .container {
       display: flex;
       justify-content: flex-end;
     }

     .item {
       width: 100px;
       height: 100px;
       background-color: #e18181;
       margin: 10px;
    }

3)、justify-content:center

html 复制代码
    <div class="container">
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
    </div>
    .container {
       display: flex;
       justify-content: center;
     }

     .item {
       width: 100px;
       height: 100px;
       background-color: #e18181;
       margin: 10px;
    }

4)、justify-content:space-between

html 复制代码
    <div class="container">
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
    </div>
    .container {
      display: flex;
      justify-content: space-between;
    }

     .item {
       width: 100px;
       height: 100px;
       background-color: #e18181;
       margin: 10px;
    }

5)、justify-content:space-around

html 复制代码
    <div class="container">
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
    </div>
    .container {
     display: flex;
     justify-content: space-around;
   }

     .item {
       width: 100px;
       height: 100px;
       background-color: #e18181;
       margin: 10px;
    }

5、align-items

①、定义

定义项目在交叉轴上如何对齐

②、语句

html 复制代码
.box {
  align-items: flex-start | flex-end | center | baseline | stretch;
}

1)、属性值

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

6、align-content

①、定义

定义了多根轴线的对齐方式。如果项目只有一根轴线,该属性不起作用

②、语句

html 复制代码
.box {
    align-content: flex-start | flex-end | center | space-between | space-around | stretch;
}

1)、属性值

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

五、容器成员属性的作用

1、order

①、定义

定义项目的排列顺序。数值越小,排列越靠前,默认为0

②、语句

html 复制代码
.item {
    order: <integer>;
}

③、代码示例

2、flex-grow

①、定义

上面讲到当容器设为 flex-wrap: nowrap;不换行的时候,容器宽度不够分的情况,弹性元素会根据 flex-grow 来决定定义项目的放大比例(容器宽度 > 元素总宽度时如何伸展)。默认为0,即如果存在剩余空间,也不放大

②、语句

html 复制代码
.item {
    flex-grow: <number>;
}

1)、属性值

  • 0(默认值):如果存在剩余空间,也不放大
  • 如果所有项目的 flex-grow 属性都为1,则它们将等份剩余空间(如果有的话)
  • 如果一个项目的flex-grow属性为2,其他项目都为1,则前者占据的剩余空间将比其他项多一倍

注意:弹性容器的宽度正好等于元素宽度总和,无多余宽度,此时无论flex-grow是什么值都不会生效

3、flex-shrink

①、定义

定义了项目的缩小比例(容器宽度<元素总宽度时如何收缩),默认为1,即如果空间不足,该项目将缩小

②、语句

html 复制代码
.item {
    flex-shrink: <number>; /* default 1 */
}

如果所有项目的flex-shrink属性都为1,当空间不足时,都将等比例缩小

如果一个项目的flex-shrink属性为0,其他项目都为1,则空间不足时,前者不缩小

在容器宽度有剩余时,flex-shrink也是不会生效的

4、flex-basis

①、定义

设置的是元素在主轴上的初始尺寸,所谓的初始尺寸就是元素在flex-grow和flex-shrink生效前的尺寸

浏览器根据这个属性,计算主轴是否有多余空间,默认值为auto,即项目的本来大小,如设置了width则元素尺寸由width/height决定(主轴方向),没有设置则由内容决定

②、语句

html 复制代码
.item {
   flex-basis: <length> | auto; /* default auto */
}

当设置为0的是,会根据内容撑开

它可以设为跟width或height属性一样的值(比如350px),则项目将占据固定空间

5、flex

①、定义

flex属性是flex-grow, flex-shrink 和 flex-basis的简写,默认值为0 1 auto,也是比较难懂的一个复合属性

②、语句

html 复制代码
.item {
  flex: none | [ <'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ]
}

1)、属性值

  • flex: 1 = flex: 1 1 0%
  • flex: 2 = flex: 2 1 0%
  • flex: auto = flex: 1 1 auto
  • flex: none = flex: 0 0 auto,常用于固定尺寸不伸缩

flex:1 和 flex:auto 的区别,可以归结于flex-basis:0和flex-basis:auto的区别

当设置为0时(绝对弹性元素),此时相当于告诉flex-grow和flex-shrink在伸缩的时候不需要考虑我的尺寸

当设置为auto时(相对弹性元素),此时则需要在伸缩时将元素尺寸纳入考虑
注意:建议优先使用这个属性,而不是单独写三个分离的属性,因为浏览器会推算相关值

6、align-self

①、定义

允许单个项目有与其他项目不一样的对齐方式,可覆盖align-items属性

默认值为auto,表示继承父元素的align-items属性,如果没有父元素,则等同于stretch

②、语句

html 复制代码
.item {
    align-self: auto | flex-start | flex-end | center | baseline | stretch;
}

六、弹性盒模型布局的应用场景

Flexbox弹性盒模型布局可以应用于几乎所有需要布局和排列元素的场景,特别是在响应式设计中非常重要。以下是一些应用场景:

  1. 垂直和水平居中元素
  2. 创建网格布局
  3. 创建自适应布局
  4. 管理空间分配和对齐
  5. 创建交错布局
  6. 创建多列布局
  7. 适应不同屏幕大小和设备

总之,Flexbox弹性盒模型布局是一种非常灵活的布局方法,可用于简单和复杂的布局需求。它还可以与其他CSS属性一起使用,例如Grid布局和响应式设计技术,这使得它在Web开发中非常有用。

七、弹性盒模型布局的优势

1、简化布局

使用弹性盒子布局可以大大简化我们对网页布局的控制,减少定位和浮动等属性的使用

2、响应式设计

弹性盒子布局适应性强,可以根据不同的设备和屏幕尺寸自动调整布局,实现响应式设计

3、灵活性强

弹性盒子布局具有非常灵活的伸缩性,能够适应各种排列和对齐需求,提供更好的布局控制

八、总结

Flex弹性布局的出现是为了满足软件界面和功能不断丰富、复杂的市场需求,它的核心诉求是子元素的尺寸要能够动态响应父元素尺寸变化,并保持一定的结构特征。

1、实现原理

在实现原理上,为了满足灵活多变的布局方式,flex布局引入一组非常重要的概念:

  • 主轴(main axis):flex项延伸的方向,决定着下一个flex项的排列位置;
  • 交叉轴(cross axis):和主轴垂直的方向,决定着主轴遇见换行情景时的具体行为细节。

2、布局工作步骤

对flex容器来说,整个布局工作可分为三步:

  • 第一步:所有flex项按照自身尺寸和主轴尺寸进行分行。简单来说,当主轴空间容纳不下flex项时,进行分行;
  • 第二步:根据上一步所得的分行信息,和每一行上flex项特征,计算本行所有flex项的主轴尺寸和布局信息;
  • 第三步:通过align-content、align-items和align-self三个属性计算所有flex项在交叉轴上的尺寸和布局信息。

总的来说,flex布局的出现让形式丰富多样的网页布局成为可能,一方面解放了工程师们的创造力,另一方面满足了要求越来越多、越来越复杂的市场需求。

相关推荐
程序员阿超的博客39 分钟前
React动态渲染:如何用map循环渲染一个列表(List)
前端·react.js·前端框架
magic 24540 分钟前
模拟 AJAX 提交 form 表单及请求头设置详解
前端·javascript·ajax
小小小小宇5 小时前
前端 Service Worker
前端
只喜欢赚钱的棉花没有糖6 小时前
http的缓存问题
前端·javascript·http
小小小小宇6 小时前
请求竞态问题统一封装
前端
loriloy6 小时前
前端资源帖
前端
源码超级联盟6 小时前
display的block和inline-block有什么区别
前端
GISer_Jing6 小时前
前端构建工具(Webpack\Vite\esbuild\Rspack)拆包能力深度解析
前端·webpack·node.js
让梦想疯狂6 小时前
开源、免费、美观的 Vue 后台管理系统模板
前端·javascript·vue.js
海云前端7 小时前
前端写简历有个很大的误区,就是夸张自己做过的东西。
前端