CSS中的Flex布局

目录

一.什么是Flex布局

二.Flex布局使用

2.1Flex使用语法

2.2基本概念

三.容器的属性

3.1所有属性概述

3.2flex-direction

3.3flex-wrap

3.4flex-flow

3.5justify-content

3.6align-items

3.7align-content

四.项目(子元素)的属性

4.1所有属性概述

4.2order

4.3flex-grow

4.4flex-shrink

4.5flex-basis

4.6flex

4.7align-self

一.什么是Flex布局

Flex布局可以:“简便、完整、响应式”的实现各种页面布局

Flex是“Flexible box”的缩写,意为“弹性布局”,用来为“盒子模型”提供“最大的灵活性

二.Flex布局使用

2.1Flex使用语法

任何一个容器都可以指定为Flex布局

使用方法

.box {display:flex;
}

行内元素也可以使用Flex布局

.box {display:inline-flex;
}

值得注意的是,使用Flex布局后,子元素的“float”、“clear”、“vertical-align”属性将失效

2.2基本概念

采用Flex布局的元素,称为Flex容器,简称“容器”,它的所有子元素自动成为容器成员,称为Flex项目,简称“项目

容器默认存在两根轴:“水平的主轴(main axis)”和“垂直的交叉轴(cross axis)

主轴开始位置(与边框的交叉点)叫“main start”,结束位置叫“main end

交叉轴开始位置叫“cross start”,结束位置叫“cross end

项目默认沿主轴排列,单个项目占据的主轴空间叫作“main size”,占据的交叉轴空间叫作“corss size

简化:“x轴为主轴”、“y轴为交叉轴

三.容器的属性

3.1所有属性概述

Flex容器一共有六大属性,在这里我们给出:

  • flex-direction:内部元素的排列方式:从左到右、从右到左、从上到下、从下到上
  • flex-wrap:子元素的换行方式:不换行、换行(第一行在上面、第二行在上面)
  • flex-flow:子元素的排列方式和换行方式的简写
  • justify-content:子元素的水平对齐方式
  • align-items:子元素的垂直对齐方式
  • align-content:设置多个元素组成的整块的对齐方式

3.2flex-direction

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

简化

内部元素的排列方式---->(从左到右、从右到左、从上到下、从下到上)

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

图示:

下面以一个代码为例,表示四个方向的排列:

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>Flex</title></head><body><div class="div"><div class="divC" style="width: 100px;height: 100px;background-color: aqua;"></div><div class="divC" style="width: 100px;height: 100px;background-color: black;"></div><div class="divC" style="width: 100px;height: 100px;background-color: blue;"></div></div><style type="text/css">.div{/* 设置为flex布局 */display: flex;/* 默认:从左往右 */flex-direction: row;/* row(默认值):主轴为水平方向,起点在左端。row-reverse:主轴为水平方向,起点在右端。column:主轴为垂直方向,起点在上沿。column-reverse:主轴为垂直方向,起点在下沿。 */}</style></body>
</html>

上面的“flex-direction”为“row”时效果:

上面的“flex-direction”为“row-reverse”时效果:

上面的“flex-direction”为“column”时效果:

上面的“flex-direction”为“column-reverse”时效果:

3.3flex-wrap

默认情况下,项目都排在一条线(轴线)上,flex-wrap定义如果一条轴线排不下,如何换行

简化

子元素的换行方式:不换行换行(第一行在上面、第二行在上面)

.box {flex-wrap:nowrap | wrap | warp-reverse;
}

nowraop(默认) 不换行

warp 换行(第一行在上)

wrap-reverse 换行(第二行在上)

3.4flex-flow

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

简化

子元素排列方式换行方式的简写

.box {flex-flow:<flex-direction> || <flex-wrap>;
}

3.5justify-content

justify-content属性定义了项目在主轴上的对齐方式

简化

设置子元素的水平对齐方式

.box {justify-content:flex-start | flex-end | center | space-between | space-around;
}

图示

详细说明

  • flex-start(默认值):左对齐
  • flex-end:右对齐
  • center:居中
  • space-between:两端对齐,项目之间的间隔相等
  • space-around:每个项目两侧的间隔相等,所以,项目之间的间隔比的项目与边框的间隔大一倍

3.6align-items

align-items属性定义项目在交叉轴上如何对齐

简化

设置子元素的垂直对齐方式

格式

.box {align-items:flex-start | flex-end | center | baseline | stretch;
}

图示

详细说明

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

3.7align-content

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

简化

设置多个元素组成的整块的对齐方式

格式

.box {align-content:flex-start | flex-end | center | space-between | space-around | stretch;
}

图示

详细说明

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

四.项目(子元素)的属性

4.1所有属性概述

  • order:按照数字大小设置各个元素之间的排列方式
  • flex-grow:按照权重分配剩余空间进行等比例放大
  • flex-shrink:按照权重进行等比例缩小
  • felx-basis:设置子元素原始所占主轴空间大小(宽度)
  • flex:设置放大、缩小和原始大小的缩写,建议优先使用此方式
  • align-self:单独设置特定元素的对齐方式,忽略“align-items”

4.2order

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

简化

按照数字大小设置各个元素之间的排列方式

格式

.item {order:<integer>;
}

图示

4.3flex-grow

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

简化

按照权重分配剩余空间进行等比例放大

格式

.item{flex-grow:<number>;
}

提示

如果所有项目的flex-grow都为1,那么它们将均匀分配剩余空间

如果某个项目flex-grow2,其余项目为1,那么前者分配到的空间将比后者大一倍

图示

4.4flex-shrink

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

简化

按照权重进行等比例缩小

格式

.item{flex-shrink:<number>;
}

提示

负值是一个无效的数值

如果某个项目属性值为0,那么该项目将不会缩小,而是让其它项目缩小

图示

4.5flex-basis

flex-basis属性定义了在分配多余空间之前项目占据的主轴空间(main size)

浏览器根据这个属性计算是否有多余空间,默认值为“auto”,即项目本来大小

简化

设置子元素原始所占主轴空间大小(宽度)

提示

它可以设为跟width或height一样的值,那么项目将会占据固定空间

格式

.item{flex-basis:<length> | auto;
}

4.6flex

flex属性是flex-grow,flex-shrink,flex-basis的简写,默认值为“0 1 auto”,后两个属性可选

简化

设置放大、缩小、原始大小的简写,建议优先使用该方式

提示

该属性有两个快捷值:“auto(1 1 auto)”、“none(0 0 auto)

建议优先写这两个快捷值

格式

.item {flex:none | [<flex-grow> <flex-shrink> <flex-basis>];
}

4.7align-self

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

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

简化

单独设置特定元素的方式,忽略align-items

格式

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

图示

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/15136.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

九、OpenAI之图片生成(Image generation)

学习用DALL.E的API怎样生成和操作图片 1 介绍 图片API提供3个方法来和图片进行交互&#xff1a; 从0开始基于文字提示创建图片(DALL.E 3 and DALL.E2)基于一个新的提示词&#xff0c;通过让模型替换已有图像的某些区域来创建图像的编辑版本;&#xff08;DALL.E2&#xff09;…

【FPGA】Verilog:解码器 | 编码器 | 多路复用器(Mux, Multiplexer)

0x00 什么是解码器 解码器是根据输入信号在多个输出位中选择一个输出位的装置。例如,当解码器接收2位二进制值作为输入时,它可以接收00、01、10、11四种输入值,并根据每个输入值在4个输出位中选择一个,输出为1000、0100、0010、0001中的一种。这样的解码器被称为高电平有效…

ICML 2024 Mamba 论文总结

2024ICML&#xff08;International Conference on Machine Learning&#xff0c;国际机器学习会议&#xff09;在2024年7月21日-27日在奥地利维也纳举行 &#x1f31f;【紧跟前沿】“时空探索之旅”与你一起探索时空奥秘&#xff01;&#x1f680; 欢迎大家关注时空探索之旅 …

IntelliJ IDEA常用快捷键 + 动图演示!

本文参考了 IntelliJ IDEA 的官网&#xff0c;列举了IntelliJ IDEA &#xff08;Windows 版&#xff09; 的所有快捷键。并在此基础上&#xff0c;为 90% 以上的快捷键提供了动图演示&#xff0c;能够直观的看到操作效果。 该快捷键共分 11 种&#xff0c;可以方便的按各类查找…

【通义千问—Qwen-Agent系列2】案例分析(图像理解图文生成Agent||多模态助手|| 基于ReAct范式的数据分析Agent)

目录 前言一、快速开始1-1、介绍1-2、安装1-3、开发你自己的Agent 二、基于Qwen-Agent的案例分析2-0、环境安装2-1、图像理解&文本生成Agent2-2、 基于ReAct范式的数据分析Agent2-3、 多模态助手 附录1、agent源码2、router源码 总结 前言 Qwen-Agent是一个开发框架。开发…

Excel提取某一列的唯一值

点击【筛选】&#xff08;【高级筛选】&#xff09;&#xff0c;参数里&#xff1a; 列表区域&#xff1a;为需要选择唯一值的那一列复制到&#xff1a;生成唯一值的目标区域 据说新版本的excel有了unique()函数&#xff0c;可以很快捷的选择某一列的唯一值&#xff0c;但是博…

仪器校准中移液器的使用规范,应当注意哪些细节?

校准行业中&#xff0c;移液器的使用是非常多的&#xff0c;尤其是理化室&#xff0c;经常需要借助到移液器来校准。作为常规的溶液定量转移器具&#xff0c;其在校准过程中的使用也需要遵守规范&#xff0c;既是保证校准结果准确低误差&#xff0c;也是为了规范实验室校准人员…

类与对象:接口

一.概念 接口&#xff08;英文&#xff1a;Interface&#xff09;&#xff0c;在JAVA编程语言中是一个抽象类型&#xff0c;是抽象方法的集合&#xff0c;接口通常以interface来声明。 二.语法规则 与定义类相似&#xff0c;使用interface关键词。 Idea可以在开始时直接创建…

动静态库

说明&#xff1a;使用动静态库&#xff0c;一般直接安装即可&#xff0c;其他使用方法了解即可 静态库 静态库&#xff08;Static Library&#xff09;是一种将代码和数据打包成一个单独的文件的库文件&#xff0c;主要用于编译时的链接&#xff0c;而不是运行时。静态库通常…

Android Studio 所有历史版本下载

一、官网链接 https://developer.android.google.cn/studio/archive 操作 二、AndroidDevTools地址 https://www.androiddevtools.cn/ 参考 https://blog.csdn.net/qq_27623455/article/details/103008937

Mybatis源码剖析---第二讲

Mybatis源码剖析—第二讲 那我们在讲完了mappedstatement这个类&#xff0c;它的一个核心作用之后呢&#xff1f;那下面我有一个问题想问问各位。作为mappedstatement来讲&#xff0c;它封装的是一个select标签或者insert标签。但是呢&#xff0c;我们需要大家注意的是什么&am…

社交媒体数据恢复:soma messenger

步骤1&#xff1a;检查备份文件 首先&#xff0c;我们需要确认您是否已开启Soma Messenger的自动备份功能。若已开启&#xff0c;您可以在备份文件中找到丢失的数据。 步骤2&#xff1a;清除缓存并重启应用 有时候&#xff0c;清除Soma Messenger的缓存文件可以帮助恢复丢失的…

为什么股票市场里有认贼为父的现象?

文章大纲&#xff1a;&#xff08;本文2648字&#xff0c;完整版本应该3500以上&#xff0c;耗时一个钟&#xff09; 1、前言&#xff1a;逻辑与博弈 2、直觉引入博弈焦点 3、上周4-5的市场博弈视角 4、下周一视角能看到的东西 5、视角背后看到的情绪周期市场共识下的博弈…

特殊变量笔记

执行demo4.sh文件,输入输出参数itcast itheima的2个输入参数, 观察效果 特殊变量&#xff1a;$# 语法 $#含义 获取所有输入参数的个数 案例需求 在demo4.sh中输出输入参数个数 演示 编辑demo4.sh, 输出输入参数个数 执行demo4.sh传入参数itcast, itheima, 播仔 看效果…

销量翻倍不是梦!亚马逊速卖通自养号测评实战技巧分享!

在亚马逊、速卖通这些跨境电商平台上&#xff0c;卖家们都在想各种办法让自己的产品卖得更好。现在&#xff0c;有一种叫做“自养号测评”的方法特别火。简单来说&#xff0c;就是自己养一些买家账号&#xff0c;然后让这些账号来给你的产品写好评。这样&#xff0c;你的产品就…

Java的反射机制以及使用场景

Java的反射机制以及使用场景 什么是反射Class对象如何使用获取 Class 类对象反射创造对象反射获取类的构造器反射获取类的成员变量反射获取类的方法 反射的应用场景JDBC 的数据库的连接Spring 框架的使用 什么是反射 Oracle 官方对反射的解释 Reflection is commonly used by p…

从零自制docker-14-【实现 mydocker commit 打包容器成镜像】

文章目录 目标注意exec.Commandtar代码结果 目标 piveroot切换工作目录到/merged后&#xff0c;通过docker commit将此时工作目录的文件系统保存下来&#xff0c;使用tar包将该文件系统打包为tar文件 命令类似 ./mydocker commit myimage然后当前目录下会得到myimage.tar 注意…

「实用推荐」如何为桌面 移动跨平台应用选择UI框架/APP架构?

DevExpress .NET MAUI UI组件库提供了用于Android和iOS移动开发的高性能UI组件&#xff0c;该库包括数据网格、图表、日程、数据编辑器、CollectionView和选项卡组件。 获取DevExpress .NET MAUI最新正式版下载(Q技术交流&#xff1a;532598169&#xff09; “一次编写&#…

ABB机器人---基础编程

目录 第一章 代码解释 1.1 基础代码 1.1.2 关于 VAR robtarget pos 1.1.3 关于四元数 1.2 机器人初始化程序 1.3 配置通信 (ProfiNet 示例&#xff0c;ABB RAPID) 1.4 设置干涉区 (ABB RAPID) 1.5 示教轨迹和自动过程 (ABB RAPID) 1.6 配置抓手并进行抓取操作 (ABB RA…