首页 web前端 css教程 CSS Flexbox 和 Grid:构建响应式布局的艺术

CSS Flexbox 和 Grid:构建响应式布局的艺术

Dec 20, 2024 am 11:03 AM

CSS Flexbox and Grid: The Art of Building Responsive Layouts

Flex灵活布局

显示: 柔性

打开 Flex 布局模式。将一个元素设置为 Flex 容器,其直接子元素将成为 Flex 项。

.container {
    display: flex;
}
登录后复制
登录后复制
登录后复制

弯曲方向

定义主轴方向(项目排列方向)。可选值:

  • 行(默认):水平,从左到右。
  • row-reverse:水平方向,从右到左。
  • 列:垂直,从上到下。
  • column-reverse:垂直,从下到上。
.container {
    flex-direction: row | row-reverse | column | column-reverse;
}
登录后复制
登录后复制
登录后复制

柔性包裹

控制当一行空间不足时是否换行。可选值:

  • nowrap(默认):不换行,物品可能会溢出容器。
  • wrap:换行,项目排列成多行。
  • wrap-reverse:换行,第一行在底部,后续行向上排列。
.container {
    flex-wrap: nowrap | wrap | wrap-reverse;
}
登录后复制
登录后复制
登录后复制

证明内容合理

定义主轴上的对齐方式。可选值:

  • flex-start(默认):项目与起点对齐。
  • flex-end:项目与终点对齐。
  • center:项目居中对齐。
  • space- Between:均匀分布项目之间的间距,第一个和最后一个项目分别附着在容器的两端。
  • space-around:项目之间均匀分布间距,项目两侧的间距相等。
  • space-evenly:均匀分布item之间的间距,item与容器边缘的间距以及item之间的间距相等。
.container {
  justify-content: flex-start | flex-end | center | space-between | space-around | space-evenly;
}
登录后复制
登录后复制
登录后复制

对齐项目

定义交叉轴上的对齐方式。可选值:

  • 拉伸(默认):项目拉伸以填充整个横轴。
  • flex-start:项目与横轴的起点对齐。
  • flex-end:项目与横轴的末端对齐。
  • center:项目以横轴为中心。
  • 基线:项目按基线对齐。
.container {
    align-items: stretch | flex-start | flex-end | center | baseline;
}
登录后复制
登录后复制
登录后复制

对齐内容

仅适用于多行Flex布局(flex-wrap:wrap),定义多行项目在横轴上的对齐方式。可选值:

  • 拉伸(默认):每行拉伸以填充整个交叉轴。
  • flex-start:每行与交叉轴的起点对齐。
  • flex-end:每行与交叉轴的末端对齐。
  • center:每行与交叉轴的中心对齐。
  • space- Between:均匀分布每行之间的空间,第一行和最后一行分别附着在容器的两端
  • space-around:均匀分布每行之间的空间,且行两侧的空间相等。
.container {
    display: flex;
}
登录后复制
登录后复制
登录后复制

命令

定义项目的顺序。值越小,阶数越高。默认值为 0。

.container {
    flex-direction: row | row-reverse | column | column-reverse;
}
登录后复制
登录后复制
登录后复制

弹性增长

定义项目的放大比例。默认值为0,表示不放大。如果所有项目都设置为非零值,则剩余空间按比例分配。

.container {
    flex-wrap: nowrap | wrap | wrap-reverse;
}
登录后复制
登录后复制
登录后复制

弯曲收缩

定义项目的收缩率。默认为1,意味着它可以收缩。如果所有项目都设置为非零值,它们会按比例缩小以防止溢出容器。

.container {
  justify-content: flex-start | flex-end | center | space-between | space-around | space-evenly;
}
登录后复制
登录后复制
登录后复制

弹性基础

定义分配剩余空间之前项目的初始大小。接受长度、百分比、自动(默认)或内容值。

.container {
    align-items: stretch | flex-start | flex-end | center | baseline;
}
登录后复制
登录后复制
登录后复制

弯曲

flex-grow、flex-shrink 和 flex-basis 的简写。默认为 0 1 自动。

.container {
    align-content: stretch | flex-start | flex-end | center | space-between | space-around;
}
登录后复制
登录后复制

自我对齐

覆盖容器的align-items属性以定义单个项目在横轴上的对齐方式。可选值与align-items相同。

.item {
    order: <integer>;
}
登录后复制

网格 网格布局

显示:网格;

打开网格布局模式。将一个元素设置为 Grid 容器,其直接子元素将成为 Grid 项(单元格)。

.item {
    flex-grow: <number>; /* Default is 0 */
}
登录后复制

网格模板列和网格模板行

定义网格的列轨道和行轨道的大小。接受长度、百分比、fr(分数单位,表示网格空间的分数)或auto值。您还可以使用repeat()函数创建重复轨道,并使用minmax()函数定义轨道的最小和最大尺寸。

.item {
    flex-shrink: <number>; /* defaults to 1 */
}
登录后复制

网格模板区域

通过命名项目并用字符串描述网格结构来定义网格布局的区域。项目名称使用 .代表一个空白单元格。

.item {
    flex-basis: <length> | <percentage> | auto | content;
}
登录后复制

网格间隙或网格列间隙和网格行间隙

设置网格中项目之间的间隙。接受长度或百分比值。

.container {
    display: flex;
}
登录后复制
登录后复制
登录后复制

网格自动列和网格自动行

定义自动填充网格时新添加的行或列的轨道大小。当项目超出定义的网格范围时生效。

.container {
    flex-direction: row | row-reverse | column | column-reverse;
}
登录后复制
登录后复制
登录后复制

网格自动流

控制网格项目如何自动填充和排列。可选值:

  • 行(默认):按行填充。
  • 列:按列填写。
  • dense:当row或column与dense一起使用时,如果网格中有间隙,新的项目将尝试填充这些间隙,而不是仅仅将它们添加到网格的末尾。
.container {
    flex-wrap: nowrap | wrap | wrap-reverse;
}
登录后复制
登录后复制
登录后复制

网格列开始、网格列结束、网格行开始和网格行结束

手动指定网格中项目的开始和结束位置。

.container {
  justify-content: flex-start | flex-end | center | space-between | space-around | space-evenly;
}
登录后复制
登录后复制
登录后复制

网格区域

同时设置 grid-row-start、grid-column-start、grid-row-end 和 grid-column-end 的简写属性,或引用 grid-template-areas 中定义的区域名称。

.container {
    align-items: stretch | flex-start | flex-end | center | baseline;
}
登录后复制
登录后复制
登录后复制

CSS Grid 与 Flexbox 结合

在某些情况下,我们可以结合 CSS Grid 和 Flexbox 的优点来创建更复杂的响应式布局。

.container {
    align-content: stretch | flex-start | flex-end | center | space-between | space-around;
}
登录后复制
登录后复制

首先,CSS Grid 用于创建具有自适应列宽的网格布局。每个网格项(子元素)都使用内部的 Flexbox 来垂直居中内容。当屏幕宽度小于 768px 时,媒体查询切换为单列布局以适应移动设备。

Flexbox 与网格选择

选择使用 Flexbox 还是 Grid 通常取决于具体需求:

  • Flexbox适合处理一维布局,例如行或列中的元素排列,以及元素对齐和填充。
  • CSS Grid 更适合处理二维布局,例如表格或复杂的网格布局,以及精确的单元格控制。

以上是CSS Flexbox 和 Grid:构建响应式布局的艺术的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

VUE 3 VUE 3 Apr 02, 2025 pm 06:32 PM

它的出局!恭喜Vue团队完成了完成,我知道这是一项巨大的努力,而且很长时间。所有新文档也是如此。

在CI/CD上有点 在CI/CD上有点 Apr 02, 2025 pm 06:21 PM

我说的“网站”比“移动应用程序”更合适,但我喜欢Max Lynch的框架:

您可以从浏览器获得有效的CSS属性值吗? 您可以从浏览器获得有效的CSS属性值吗? Apr 02, 2025 pm 06:17 PM

我有人写了这个非常合法的问题。 Lea只是在博客上介绍了如何从浏览器中获得有效的CSS属性。那样的是这样。

在WordPress块编辑器中使用Markdown和本地化 在WordPress块编辑器中使用Markdown和本地化 Apr 02, 2025 am 04:27 AM

如果我们需要直接在WordPress编辑器中向用户显示文档,那么最佳方法是什么?

带有粘性定位的堆叠卡和一点点的杂物 带有粘性定位的堆叠卡和一点点的杂物 Apr 03, 2025 am 10:30 AM

前几天,我发现了科里·金尼文(Corey Ginnivan)网站上的这一点,当您滚动时,彼此之间的卡片堆放集。

比较浏览器的响应式设计 比较浏览器的响应式设计 Apr 02, 2025 pm 06:25 PM

这些桌面应用程序中有许多目标是同时在不同的维度上显示您的网站。因此,例如,您可以写作

如何将CSS网格用于粘头和页脚 如何将CSS网格用于粘头和页脚 Apr 02, 2025 pm 06:29 PM

CSS网格是一系列属性的集合,旨在使布局比以往任何时候都容易。像任何东西一样,那里有一点学习曲线,但是网格是

Google字体可变字体 Google字体可变字体 Apr 09, 2025 am 10:42 AM

我看到Google字体推出了新设计(Tweet)。与上一次大型重新设计相比,这感觉更加迭代。我几乎无法分辨出区别

See all articles