首页 > 其他分享 >一文搞懂flex(弹性盒布局)

一文搞懂flex(弹性盒布局)

时间:2024-11-27 11:05:23浏览次数:3  
标签:flex 一文 交叉 align 项目 对齐 搞懂 属性

1、什么是弹性布局

Flex是Flexible Box的缩写,翻译成中文就是“弹性盒子”,用来为盒装模型提供最大的灵活性。任何一个容器都可以指定为Flex布局。

她是一种现代的CSS布局方式,通过使用display: flex属性来创建一个弹性容器,可以自动适配各种设备的不同宽度,而不必依赖于传统的块状布局和浮动定位,并在其中使用灵活的盒子模型来进行元素的排列和定位。

在浏览器支持完美的环境中,选择使用弹性盒子的原因是你希望把一系列项目沿着同一方向布局。因为在放置元素过程中,你想控制元素在那个方向的维度,或者控制它们彼此之间的间距。弹性盒子就是为此设计的。

2、弹性布局的特点

  • 主轴与交叉轴:弹性容器具有主轴(main axis)和交叉轴(cross axis)。默认情况下,主轴是水平方向,交叉轴是垂直方向。

  • 弹性容器:通过将父元素的display属性设置为flex或inline-flex来创建弹性容器。

  • 子元素的弹性项目:弹性容器中的每个子元素都成为弹性项目。子元素可以指定各自在主轴和交叉轴上的大小、顺序以及对齐方式等。

  • 主轴对齐:弹性项目可以在主轴上按照一定比例分配空间,也可以使用justify-content属性定义主轴的对齐方式。

  • 交叉轴对齐:弹性项目可以在交叉轴上进行对齐,包括顶部对齐、底部对齐、居中对齐等,使用align-items属性定义交叉轴对齐方式。

  • 换行与自动调整:可控制弹性项目是否换行,并且具备自动调整元素大小的能力。

  • 弹性布局简化了网页布局的开发过程,提供了更灵活、响应式的布局方式。它适用于各种屏幕尺寸和设备类型,并能够快速适应不同的布局需求。

弹性布局

3、Flex容器

我们把一个容器的 display 属性值改为 flex 或者 inline-flex 之后,该容器就变成了 Flex 容器,而容器中的直系子元素就会变为 flex 元素。如下代码所示,parent 元素就是 Flex 容器,son 元素就是 Flex 元素。

Flex容器

<style>
#parent {
    display: flex;
}
</style>
<div id="parent">
    <div id="son"></div>
</div>

由于所有 CSS 属性都会有一个初始值,所以 flex 容器中的所有 flex 元素都会有下列行为:

  • 元素排列为一行(flex-direction 属性的初始值是 row)。
  • 元素从主轴的起始线开始。
  • 元素不会在主维度方向拉伸,但是可以缩小。
  • 元素被拉伸来填充交叉轴大小。
  • flex-basis 属性为 auto
  • flex-wrap 属性为 nowrap

4、Flex容器属性

Flex容器属性

4.1、flex-direction:决定主轴的方向(即项目的排列方向)

.box {
   flex-direction: row | row-reverse | column | column-reverse;
}

如果你选择了 row 或者 row-reverse,那么主轴(Main Axis)就是横向的 X 轴,交叉轴(Cross Axis)就是竖向的 Y 轴,如下图所示。

主轴是横向的X轴,交叉轴是竖向的Y轴

如果你选择了 column 或者 column-reverse,那么主轴(Main Axis)就变成是竖向的 Y 轴,交叉轴(Cross Axis)就是横向的 X 轴,如下图所示。

主轴是竖向的Y轴,交叉轴是横向的X轴

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

flex-direction:决定主轴的方向(即项目的排列方向)

4.2、flex-wrap:定义换行情况

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

flex-wrap:定义换行情况

默认元素排列在一条轴线上,如果一条轴线排不下,此时就可以用flex-wrap属性处理。

.box{
   flex-wrap: nowrap | wrap | wrap-reverse;
}
  • nowrap(默认):不换行

nowrap(默认):不换行

  • wrap:换行,第一行在上方
    wrap:换行,第一行在上方

  • wrap-reverse:换行,第一行在下方

wrap-reverse:换行,第一行在下方

4.3、justify-content:定义项目在主轴上的对齐方式

justify-content 属性用来使元素在主轴方向上对齐,它的初始值是 flex-start,即元素从容器的起始线排列。justify-content 属性有如下 5 个不同的值:

  • flex-start(默认值):左对齐、从起始线开始排列,默认值。
  • flex-end:右对齐、从终止线开始排列。
  • center: 居中、在中间排列。
  • space-between:两端对齐,项目之间的间隔都相等。
  • space-around:每个项目两侧的间隔相等。所以,项目之间的间隔比项目与边框的间隔大一倍。

 justify-content

对齐方式与轴的方向有关,本文中假设主轴从左到右。

.box {
   justify-content: start | end | flex-start | flex-end | center | left | right | space-between | space-around | space-evenly | stretch | safe | unsafe | baseline | first baseline | last baseline;
}
  • flex-start(默认值):左对齐

左对齐

  • flex-end:右对齐

右对齐

  • center:居中

居中对齐

  • space-between:两端对齐,项目之间间隔相等

两端对齐

  • space-around:每个项目两侧的间隔相等,即项目之间的间隔比项目与边框的间隔大一倍

两侧间隔相等

4.4、align-items:定义在交叉轴上的对齐方式

align-items 属性可以使元素在交叉轴方向对齐,它的初始值是 stretch,即拉伸到最高元素的高度。align-items 属性有如下 5 个不同的值:

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

align-items

对齐方式与交叉轴的方向有关,假设交叉轴从下到上。

.box{
    align-items: flex-start | flex-end | center | baseline | stretch;
}
  • flex-start:起点对齐

起点对齐

  • flex-end:终点对齐

终点对齐

  • center:中点对齐

中点对齐

  • baseline:项目的第一行文字的基线对齐

基线对齐

  • stretch(默认值):如果项目未设置高度或设为auto,将占满整个容器的高度

stretch(默认值)

4.5、align-content:定义多根轴线的对齐方式

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

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

如果项目只有一根轴线,该属性不起作用。
所以,容器必须设置flex-wrap:···;

.box{
    align-content: flex-start | flex-end | center | space-between | space-around | stretch;
}
  • flex-start:与交叉轴的起点对齐

起点对齐

  • flex-end:与交叉轴的终点对齐

终点对齐

  • center:与交叉轴的中点对齐

中点对齐

  • space-between:与交叉轴的两端对齐,轴线之间的间隔平均分布

轴线之间等间距

  • space-around:每根轴线两侧的间隔相等,即轴线之间的间隔比轴线与边框的间隔大一倍

轴线两侧等间距

  • stretch(默认值):轴线占满整个交叉轴

项目未设置高度时

当你不给项目设置高度但是给容器设置align-content不为stretch时,同一轴线上的项目的高度将等于项目中高度最高的项目。

img

4.6、align-content 和 align-items 区别

  • align-items 适用于单行情况下,只有上对齐、下对齐、居中和 拉伸。
  • align-content适应于换行(多行)的情况下(单行情况下无效),可以设置上对齐、下对齐、居中、拉伸以及平均分配剩余空间等属性值。
  • 总结就是单行找 align-items 多行找 align-content。

align-content 和 align-items 区别

5、项目属性(Item)

设置在项目上的属性也有6个。

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

项目属性

5.1、order属性:定义项目的排列顺序

数值越小,排列越靠前,默认为0,可以是负值。

.item {
    order: <整数>;
}

order属性:定义项目的排列顺序

5.2、flex-grow属性

flex-grow属性定义项目的放大比例,默认为0,即如果存在剩余空间,也不放大。

.item{
    flex-grow: <数字>;
}

如果所有项目的flex-grow属性都为1,则它们将等分剩余空间(如果有的话)。如果一个项目的flex-grow属性为2,其他项目都为1,则前者占据的剩余空间将比其他项多一倍。

flex-grow属性

5.3、flex-shrink属性

flex-shrink属性定义了项目的缩小比例,默认为1,即如果空间不足,该项目将缩小。

.item {
  flex-shrink: <number>; /* default 1 */
}

flex-shrink属性

如果所有项目的flex-shrink属性都为1,当空间不足时,都将等比例缩小。如果一个项目的flex-shrink属性为0,其他项目都为1,则空间不足时,前者不缩小。

负值对该属性无效。

5.4、align-self属性

align-self属性允许单个项目有与其他项目不一样的对齐方式,可覆盖align-items属性。默认值为auto,表示继承父元素的align-items属性,如果没有父元素,则等同于stretch

.item {
  align-self: auto | flex-start | flex-end | center | baseline | stretch;
}

align-self属性

看到这里,关于 Flex 布局的核心点就介绍得差不多了。掌握好这几个核心的知识点,再去实践练习基本上没有什么太大的问题。剩下一些比较小众的属性,等用到时再去查查看就是了。

6、参考资料

弹性盒子-https://developer.mozilla.org/zh-CN/docs/Glossary/Flexbox

弹性盒布局-https://developer.mozilla.org/zh-CN/docs/Web/CSS/CSS_flexible_box_layout/Basic_concepts_of_flexbox

FlexTest-https://flexbox.help/

Flex 布局教程:语法篇

Flexbox 布局的最简单表单

【保姆级教程】Vue项目调试技巧

干货|工作中要使用Git,看这篇文章就够了

Vue 前端开发团队风格指南(史上最全)

企业数字化转型如何做?看过来

干货-Vue3 组件通信方式详解

【长文】带你搞明白Redis

标签:flex,一文,交叉,align,项目,对齐,搞懂,属性
From: https://www.cnblogs.com/huyong/p/18571786

相关文章

  • flex布局下,内容使用truncate不显示省略号的问题
    <divclass="flexitems-center"><divclass="w-10h-10mr-4">头像</div><divclass="flex-1"><divclass="text-lg">姓名</div><divclass="truncate">内容内容内容内容内......
  • 一文讲清!实现 OA 办公系统有哪些流程?
    相信大家看了我前几篇文章,已经对OA系统有了基本认识。OA(OfficeAutomation)办公系统作为现代化办公管理工具,能有效提升企业工作效率、信息共享和沟通协作能力。下面详细探讨实现OA办公系统的步骤,为企业提供参考。第一步:明确需求与目标实施OA办公系统前,需明确企业的需求与目......
  • 一文看懂一个专业丨计算机科学与技术。从零基础到精通,收藏这篇就够了!
    1、计算机学什么?①工科基础:高数、大学物理、大学英语、政治等②编程语言:C语言、C++、Java、Python等③开发环境:Linux、嵌入式、移动端等④专业素养:数据结构、计算机组成原理、计算机网络原理、通信原理等⑤选修模块(更前沿的计算机):AI、大数据、计......
  • 一文看懂为啥游资开始卷交易网关
    什么是交易网关:上交所全新自主研发基于流式接口的交易网关(TDGW)客户端报单软件。本次推出的交易网关具有高性能、低时延、跨平台、开放易用等优点,同时为支撑集约化管理提供集中监控终端和监控接口,以全面满足市场参与者对交易报单软件的业务价值需求。目前可支持股票期权委托申......
  • C语言基础——彻底搞懂C指针(六)
    整理自《彻底搞定C指针》,有兴趣的读者可以找原版电子版阅读。其他内容见:C语言基础——彻底搞懂C指针(一)-CSDN博客C语言基础——彻底搞懂C指针(二)-CSDN博客C语言基础——彻底搞懂C指针(三)-CSDN博客C语言基础——彻底搞懂C指针(四)-CSDN博客C语言基础——彻底搞懂C指针(五)-CSDN博......
  • 一文搞懂 volatile:多线程编程的关键基础
    1.引言1.1什么是volatile?volatile是一个常用于多线程编程的关键字,其主要作用是确保线程对共享变量的访问保持最新状态。在现代计算机中,由于CPU缓存和编译器优化的存在,线程可能会读取到共享变量的旧值,导致逻辑错误。通过声明变量为volatile,我们可以告诉编译器和运行......
  • Linux中Find命令也能提权?提权方式一文通透
    前言在信息安全的广阔领域中,系统命令的权限设置至关重要。find命令作为Linux常用的文件查找工具,在日常管理中广泛应用。然而,当find命令被错误地赋予SUID权限时,它可能成为攻击者执行特权操作、实现权限提升的工具。本文深入探讨find命令的常规用法,展示其在特定权限设置下的......
  • 一文学习Android系统核心服务ServiceManager
    ServiceManager是Android系统中核心的系统服务注册与发现机制,它在AndroidFramework层扮演服务注册中心的角色。它允许进程通过它注册、查询和使用系统服务,实现进程间通信(IPC)的基础架构。ServiceManager的作用服务注册:应用程序或系统组件可以将一个Binder对象......
  • 【请收藏】一文带你走进云安全
    云安全是指一系列用于保护云计算环境中数据、应用程序、基础设施和用户免受各种安全威胁的策略、技术和措施。它涵盖了云计算服务提供商和使用云服务的用户共同的安全责任,涉及数据在云端存储、处理和传输过程中的完整性、保密性和可用性。一、云计算的发展1、起源阶段虚......
  • 一文讲解SSH你一定不知道的八大黑科技玩法,网络安全零基础入门到精通教程建议收藏!
    SSH(SecureShell)是什么?是一项创建在应用层和传输层基础上的安全协议,为计算机上的Shell(壳层)提供安全的传输和使用环境。也是专为远程登录会话和其他网络服务提供安全性的协议。它能够有效防止远程管理过程中的信息泄露问题。通过SSH可以对所有传输的数据进行加密,也能够防......