当前位置: 首页 > news >正文

flex 下对齐_开启 flex 与 grid 布局方式之旅

关注“前端学苑” ,坚持每天进步一点点

cf6c0f15e3ef615ce1ec911357630b88.png

「~布局flex 与 grid~」

现在,我们被称为前端工程师。然而,早年给我们的称呼却是页面仔。或许是职责越来越大,整体的前端井喷式的发展,使我们只关注了js,而疏远了css和html。本文主要是介绍 flex 布局和 grid 布局。

CSS 常见布局方式

c9d26d85fec9707f1d7def873779ba77.png「~思维导图~」

一、文档流布局

这是最基本的布局方式,就是按照文档的顺序一个一个显示出来,块元素独占一行,行内元素共享一行。

二、浮动布局

浮动方式布局就是使用 float 属性,使元素脱离文档流,浮动起来。

三、定位布局

可以通过 position 属性来进行定位。

四、flex 布局

9084ab1092a6a3618fd79dd292bc8e6f.png

什么是 flex 布局

2009年,W3C 提出了一种新的方案----Flex 布局,可以简便、完整、响应式地实现各种页面布局。目前,它已经得到了所有浏览器的支持,这意味着,现在就能很安全地使用这项功能。

Flex 是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性。

flex 是一种新型的布局方式,使用该布局方式可以实现几乎所有你想要的效果。但是要注意其浏览器的兼容性,flex 只支持 ie 10+,所有还是要根据你的项目情况使用。

42919b9a0221bcb3b1f43597fa4ebebd.png

flex 的浏览器支持情况

使用 flex 布局

flex 的使用方法很简单,只需要将其 display 属性设置为 flex 就可以,也可以设置行内的 flex。注意:设为 Flex 布局以后,子元素的 float、clearvertical-align 属性将失效。

在 flex 中,最核心的概念就是容器和轴,所有的属性都是围绕容器和轴设置的。其中,容器分为父容器和子容器。轴分为主轴和交叉轴(主轴默认为水平方向,方向向右,交叉轴为主轴顺时针旋转 90°)。

在使用 flex 的元素中,默认存在两根轴:水平的主轴(main axis)和垂直的交叉轴(cross axis)主轴开始的位置称为 main start,主轴结束的位置称为 main end。交叉轴开始的位置称为 cross start,交叉轴结束的位置称为 cross end。
在使用 flex 的子元素中,占据的主轴空间叫做 main size,占据的交叉轴空间叫做 cross size。

480d71b1a92bc7405393045858304562.png

flex 基本概念

父容器属性

父容器上有六个属性

1)flex-direction:主轴的方向。

2)flex-wrap:超出父容器子容器的排列样式。

3)flex-flow:flex-direction 属性和 flex-wrap 属性的简写形式。

4)justify-content:子容器在主轴的排列方向。

5)align-items:子容器在交叉轴的排列方向。

6)align-content:多根轴线的对齐方式。

flex-direction 属性
flex-direction 属性决定主轴的方向(主轴的方向不一定是水平的,这个属性就是设置主轴的方向,主轴默认是水平方向,从左至右,如果主轴方向设置完毕,那么交叉轴就不需要设置,交叉轴永远是主轴顺时针旋转 90°)。
.ele {  flex-direction: row;                // 默认值,主轴为水平方向,起点在左端。  flex-direction: row-reverse;        // 主轴为水平方向,起点在右端。  flex-direction: column;             // 主轴为垂直方向,起点在上。  flex-direction: column-reverse;     // 主轴为垂直方向,起点在下。}
b09a2be419bf4674709da35edc25109e.png flex-direction 属性

flex-wrap 属性
flex-wrap 属性决定子容器如果在一条轴线排不下时,如何换行。

.ele { flex-wrap: nowrap;          // 默认,不换行 flex-wrap: wrap;            // 换行,第一行在上方。 flex-wrap: wrap-reverse     // 换行,第一行在下方。

cdf650b00cff90342e6dfa581cb0e264.png

flex-wrap 属性

justify-content 属性

justify-content 属性定义了子容器在主轴上的对齐方式。

.ele{    justify-content: flex-start;      // 默认,左对齐    justify-content: flex-end;        // 右对齐    justify-content: center;          // 居中    justify-content: space-between;   // 两端对齐,项目之间的间隔都相等。    justify-content: space-around;    // 每个项目两侧的间隔相等。所以,项目之间的间隔比项目与边框的间隔大一倍。}

019e61d2ddf14fd41cab125d81dfac79.png

justify-content 属性

flex-flow 属性

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

.ele {  flex-flow:  || ;}

align-items 属性

align-items属性定义子容器在交叉轴上如何对齐。
具体的对齐方式与交叉轴的方向有关,下面假设交叉轴从上到下。

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

53c025621bdfc55a22835b2c25ee2499.png

align-items 属性

align-content 属性

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

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

bcd821c4552d2bdda87889055e520eb4.png

align-content 属性

子容器属性

子容器也有 6 个属性:

1)order:子容器的排列顺序

2)flex-grow:子容器剩余空间的拉伸比例

3)flex-shrink:子容器超出空间的压缩比例

4)flex-basis:子容器在不伸缩情况下的原始尺寸

5)flex:子元素的 flex 属性是 flex-grow,flex-shrink 和  flex-basis 的简写

6)align-self

order 属性

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

.ele{   order: num; }

29b695ef5e8cde27894053fb6b56bc43.png

order 属性

flex-grow 属性

flex-grow 属性定义子容器的伸缩比例。按照该比例给子容器分配空间。

.ele{    flex-grow: ; /* default 0 */}

a2d0a846caafe62298b2671164188d88.png

flex-grow 属性

flex-shrink 属性

flex-shrink 属性定义了子容器弹性收缩的比例。如图,超出的部分按 1:2 的比例从子容器中减去。此属性要生效,父容器的 flex-wrap 属性要设置为 nowrap。

.ele{    flex-shrink: ; /* default 0 */}

8560f77261e7cedd3f24b49c613200f4.png

flex-shrink 属性

flex-basis 属性

flex-basis 属性定义了子容器在不伸缩情况下的原始尺寸,主轴为横向时代表宽度,主轴为纵向时代表高度。

.ele{    flex-basis:  | auto; /* default auto */}

7a3e87d409c7a4f62b285d6c4fee3877.png

flex-basis 属性

五、grid 网格布局

flex 布局虽然强大,也是一维布局,只能在一条直线上放置内容区块。

grid 布局又称为“网格布局”,可以实现二维布局方式,和之前的 表格table布局差不多,然而,这是使用 CSS 控制的,不是使用 HTML 控制的,同时还可以依赖于媒体查询根据不同的上下文新定义布局。

与 table 布局不同的是,grid 布局不需要在 HTML 中使用特定的标签布局,所有的布局都是在 CSS 中完成的,你可以随意定义你的 grid 网格。

浏览器兼容性如下:

5dce011223b2b4848dc468114435db9a.png

浏览器兼容

grid 网格布局中的基本概念

网格线(Grid Lines)

网格线组成了网格,网格的水平和垂直的分界线。一个网格线存在行或列的两侧。我们可以引用它的数目或者定义的网格线名称。

3fedceca2d2600a20ac0b6ca747250a7.png

网格线(Grid Lines)

网格轨道(Grid Track)

网格轨道是就是相邻两条网格线之间的空间,就好比表格中行或列。所在在网格中其分为grid column和grid row。每个网格轨道可以设置一个大小,用来控制宽度或高度。

08e997b966e3d75b51fafaea6269d11c.png
网格轨道(Grid Track)

网格单元格(Grid Cell)

网格单元格是指四条网格线之间的空间。所以它是最小的单位,就像表格中的单元格。

25fdd6013381ed44102dbac20958f5ad.png
网格单元格(Grid Cell)

网格区域(Grid Area)

网格区域是由任意四条网格线组成的空间,所以他可能包含一个或多个单元格。相当于表格中的合并单元格之后的区域。

8e33c8a60168635000fa39525d8ddfc5.png
网格区域(Grid Area)

使用 grid 布局

display:grid | inline-grid | subgrid

网格容器中的所有子元素就会自动变成网格项目(grid item),然后设置列(grid-template-columns)和 行(grid-template-rows)的大小,设置 grid-template-columns 有多少个参数生成的 grid 列表就有多少个列。

注:当元素设置了网格布局,column、float、clear、vertical-align属性无效。

* 举个栗子 ?

1、第一个 Grid 布局

CSS Grid 布局由两个核心组成部分是 wrapper(父元素)和 items(子元素)。wrapper 是实际的 grid(网格),items 是 grid(网格) 内的内容。

1
2
3
4
5
6

要把 wrapper 元素变成一个 grid(网格),只要简单地把其 display 属性设置为 grid 即可:

.wrapper {    display: grid;}
每个模块添加了不同背景色,效果如下: 4dac59aa061900990c3f86e3e4988af0.png

Columns(列) 和 rows(行)为了使其成为二维的网格容器,我们需要定义列和行。让我们创建3列和2行。我们将使用grid-template-row和grid-template-column属性。

.wrapper {    display: grid;    grid-template-columns: 100px 100px 100px;    grid-template-rows: 50px 50px;}

正如你所看到的,我们为 grid-template-columns 写入了 3 个值,这样我们就会得到 3 列。我们想要得到 2 行,因此我们为 grid-template-rows 指定了2个值。

这些值决定了我们希望我们的列有多宽( 100px ),以及我们希望行数是多高( 50px )。

效果如下:

78e0d8ca8f57483ec5e5faaf07136611.png

为了确保你能正确理解这些值与网格外观之间的关系,请看一下这个例子。

.wrapper {    display: grid;    grid-template-columns: 200px 50px 100px;    grid-template-rows: 100px 30px;}
效果如下:

47778c35fdcba052da5062ff4b516874.png

2、第二个 Grid 布局

grid-template-rows,grid-template-columns: 设置行、列的尺寸:

1)fr:是一个占比单位,占容器的比例;

2)repeat(n, size) : 重复多少次,大小是多大;

3)minmax(min, max) : 取值范围 >= min, <= max;

4)auto:根据浏览器决定大小;

tips: fr 是基于网格容器可用空间来计算的(flex 也是一样),所以我们可以和其他单位混合使用,如果需要的话。
<div class="container">        <div>Onediv>        <div>Twodiv>        <div>Threediv>        <div>Fourdiv>        <div>Fivediv>        <div>Sixdiv>        <div>Sevendiv>    div>
.container {            display: grid;            grid-template-columns: repeat(3, 200px);            grid-template-rows: minmax(200px, 1fr) 100px auto;        }        .container > div {            border-radius: 5px;            padding: 10px;            background-color: rgb(207,232,220);            border: 2px solid rgb(79,185,227);        }
效果如下:

29e4e924d4401782c81081e80fcd1b68.png

gap、column-gap、row-gap 设置间隔,设置列间的间隔为 10px,行间的间隔为 20px。grid-gap 为 row-gap 和 column-gap 的缩写:
.container {    column-gap: 10px;    row-gap: 20px;}

效果如下:

762385c23696d7adec778c613adb6213.png

觉得本文对你有帮助?请分享给更多人

关注「前端学苑」加星标,提升前端技能

2439633573adb4db85c462045bd5e1d0.png

相关文章:

  • python中的and or的区别_Python 中 (,|)和(and,or)之间的区别
  • python csv模块dictwrite_Pythoncsv.DictWriterwriterow()返回
  • dataset__getitem___PyTorch 之Dataset和DataLoader
  • java 读取txt内容_不用怀疑!这就是把Java.I/O流讲解的最清楚的一篇文章
  • 表单所有input框置灰_别再对 Angular 表单的 ControlValueAccessor 感到迷惑
  • 要求的函数不受支持_支持向量机:如何对不可分数据进行分类?
  • java 内存泄漏_Java应用程序中的内存泄漏及内存管理
  • python制作网页样式_HTML基础做出属于自己的完美网页
  • using在sql中是什么意思_知否 | “开到荼蘼”的“荼蘼”是什么东西?
  • python如何导入数据库生成图表_python数据库操作常用功能使用详解(创建表/插入数据/获取数据)...
  • python pip3 freeze_Python系列之包管理工具【pip3】
  • python元组倒序排列_python序列(列表,元组,字典)的常用排序
  • python k线顶分型_顶分型和底分型的确认及K线包含处理
  • oracle大量删除数据之后索引是否需要重建_深入浅出索引
  • python3.70_Python 2.7 辛苦了,你好Python 3.7
  • 002-读书笔记-JavaScript高级程序设计 在HTML中使用JavaScript
  • 2017年终总结、随想
  • 2019年如何成为全栈工程师?
  • Angular6错误 Service: No provider for Renderer2
  • IndexedDB
  • java8-模拟hadoop
  • Java编程基础24——递归练习
  • Java读取Properties文件的六种方法
  • MySQL用户中的%到底包不包括localhost?
  • rabbitmq延迟消息示例
  • vue从创建到完整的饿了么(11)组件的使用(svg图标及watch的简单使用)
  • Vue官网教程学习过程中值得记录的一些事情
  • Web Storage相关
  • 大数据与云计算学习:数据分析(二)
  • 分类模型——Logistics Regression
  • 精益 React 学习指南 (Lean React)- 1.5 React 与 DOM
  • 为物联网而生:高性能时间序列数据库HiTSDB商业化首发!
  • 一个SAP顾问在美国的这些年
  • 主流的CSS水平和垂直居中技术大全
  • 追踪解析 FutureTask 源码
  • 你学不懂C语言,是因为不懂编写C程序的7个步骤 ...
  • ​​​​​​​ubuntu16.04 fastreid训练过程
  • ​MPV,汽车产品里一个特殊品类的进化过程
  • ​软考-高级-系统架构设计师教程(清华第2版)【第1章-绪论-思维导图】​
  • #LLM入门|Prompt#1.8_聊天机器人_Chatbot
  • #vue3 实现前端下载excel文件模板功能
  • #考研#计算机文化知识1(局域网及网络互联)
  • (delphi11最新学习资料) Object Pascal 学习笔记---第5章第5节(delphi中的指针)
  • (java)关于Thread的挂起和恢复
  • (PyTorch)TCN和RNN/LSTM/GRU结合实现时间序列预测
  • (八十八)VFL语言初步 - 实现布局
  • (附源码)ssm智慧社区管理系统 毕业设计 101635
  • (蓝桥杯每日一题)平方末尾及补充(常用的字符串函数功能)
  • (四)图像的%2线性拉伸
  • (续)使用Django搭建一个完整的项目(Centos7+Nginx)
  • (学习日记)2024.02.29:UCOSIII第二节
  • (转)Groupon前传:从10个月的失败作品修改,1个月找到成功
  • (转)jQuery 基础
  • *(长期更新)软考网络工程师学习笔记——Section 22 无线局域网
  • .gitattributes 文件