CSS Grid Layout 网格布局用法
以前是 tables,后来是 margins 和 floats,再后来是 flexbox ,现在是网格:CSS 总是以新的、更好的方式来简化网页布局编码这项古老的工作。CSS 网格布局模型(CSS Grid Layout Model)可以沿水平和垂直两条轴线创建和更新布局,同时影响元素的宽度和高度。
网格布局并不依赖于元素在标记中的位置,因此你可以在不改变布局的情况下调整元素在标记中的位置。在网格模型中,网格容器元素被网格线划分为网格列和行(统称为网格轨)。现在,让我们来看看如何创建一个网格示例。
Grid 网格示例
要将元素转化为网格容器,可以使用以下三种显示属性之一:
display: grid;
– 将元素转换为块状网格容器display: inline-grid;
– 将元素转换为内联网格容器display: subgrid;
– 如果元素是网格项,它将转换为忽略网格模板和网格间隙属性的子网格
正如表格由多个表格单元格组成一样,网格也由多个网格单元格组成。网格项被分配给一组网格单元,这些网格单元统称为网格区域。
我们将创建一个包含五个部分(网格区域)的网格:顶部、底部、左侧、右侧和中央。HTML 由容器 div 内的五个 div 组成。
<div class="grid-container"> <div class="grid-top">Top</div> <div class="grid-left">Left</div> <div class="grid-centre">centre</div> <div class="grid-right">Right</div> <div class="grid-bottom">Bottom</div> </div>
在 CSS 中,grid-template-areas
属性定义了具有不同网格区域的网格。在其值中,字符串代表网格行,字符串中的每个有效名称代表一列。要创建空网格单元格,需要在行字符串中使用点(.
)字符。
网格区域名称可通过各个网格项的 grid-area
属性引用。
.grid-container { width: 500px; height: 500px; display: grid; grid-template-areas: "top top top" "left centre right" "bottom bottom bottom"; } .grid-top { grid-area: top; } .grid-bottom { grid-area: bottom; } .grid-left { grid-area: left; } .grid-right { grid-area: right; } .grid-centre{ grid-area: centre; }
因此,这段代码会创建一个有三行三列的网格。最上面的 top
元素占据第一行三列的区域,最下面的 bottom
元素占据最后一行三列的区域。left
, centre
和 right
的每个元素都占用中间一行的一列。
现在,我们需要为这些行和列分配尺寸。grid-template-columns
和 grid-template-rows
属性定义了网格轨道的大小(行或列)。
.grid-container { width: 500px; height: 500px; display: grid; grid-template-areas: "top top top" "left centre right" "bottom bottom bottom"; grid-template-columns: 100px auto 100px; grid-template-rows: 50px auto 150px; }
这就是我们的 CSS 网格现在的样子(增加了一些样式):
data:image/s3,"s3://crabby-images/81b9f/81b9f4fac6ee4ba3b38968e255d19866a797efc2" alt="图0:CSS Grid Layout 网格布局用法 图0:CSS Grid Layout 网格布局用法"
网格元素之间的空隙
您可以使用 column-gap
和 row-gap,
或简写属性 gap
在列和行之间添加空白间隔。
.grid-container { width: 500px; height: 500px; display: grid; grid-template-areas: "top top top" "left centre right" "bottom bottom bottom"; grid-template-columns: 100px auto 100px; grid-template-rows: 50px auto 150px; gap: 5px 5px; }
下图显示, gap
属性确实在网格项之间添加了间隙。
data:image/s3,"s3://crabby-images/61fbc/61fbc847ea58c1cc1d3de0990d7387343d9e1fa7" alt="图1:CSS Grid Layout 网格布局用法 图1:CSS Grid Layout 网格布局用法"
对齐网格内容和子元素
网格容器(.grid-container
)的 justify-content
属性可使网格内容沿内联轴(水平轴)对齐,而 align-content
属性可使网格内容沿块轴(垂直轴)对齐。这两个属性都可以有以下值:start
, end
, center
, space-between
, space-around
和 space-evenly
。
在适用的情况下,轨道(行或列)的大小会缩小,以适应对齐时的内容。请看下面用不同值对齐的网格内容截图。
justify-content: start;
data:image/s3,"s3://crabby-images/145a9/145a9ad9903892aedd66f570c24285153fb16b93" alt="图2:CSS Grid Layout 网格布局用法 图2:CSS Grid Layout 网格布局用法"
justify-content: end;
data:image/s3,"s3://crabby-images/3635d/3635d6e667d76dbd73463522410c279a5d36f082" alt="图3:CSS Grid Layout 网格布局用法 图3:CSS Grid Layout 网格布局用法"
justify-content: center;
data:image/s3,"s3://crabby-images/2e021/2e021ea4f8bd95c10a4cff93e3a44abdcc924fa2" alt="图4:CSS Grid Layout 网格布局用法 图4:CSS Grid Layout 网格布局用法"
justify-content: space-between;
data:image/s3,"s3://crabby-images/1842f/1842faa76fe40f90245a02700c8e843cb8b44384" alt="图5:CSS Grid Layout 网格布局用法 图5:CSS Grid Layout 网格布局用法"
justify-content: space-around;
data:image/s3,"s3://crabby-images/312f0/312f0eb76f03cbc2bfd4eaad3cf1d838b9942b72" alt="图6:CSS Grid Layout 网格布局用法 图6:CSS Grid Layout 网格布局用法"
justify-content: space-evenly;
data:image/s3,"s3://crabby-images/3b5fd/3b5fddba7d3d191edc83f0c379ea52d6fc04d06f" alt="图7:CSS Grid Layout 网格布局用法 图7:CSS Grid Layout 网格布局用法"
align-content: start;
data:image/s3,"s3://crabby-images/1a84f/1a84f1870d2d8652d5f7916b7493bea2228da1b2" alt="图8:CSS Grid Layout 网格布局用法 图8:CSS Grid Layout 网格布局用法"
align-content: end;
data:image/s3,"s3://crabby-images/01cf3/01cf3643702ca0fef71aa1ad59c23ec827f8a3f9" alt="图9:CSS Grid Layout 网格布局用法 图9:CSS Grid Layout 网格布局用法"
align-content: center;
data:image/s3,"s3://crabby-images/fbed3/fbed3f24472c8109b5df4717a70db645944dcb9e" alt="图10:CSS Grid Layout 网格布局用法 图10:CSS Grid Layout 网格布局用法"
align-content: space-between;
data:image/s3,"s3://crabby-images/90efc/90efc019d8f9ae53037130897c135628abc112f6" alt="图11:CSS Grid Layout 网格布局用法 图11:CSS Grid Layout 网格布局用法"
align-content: space-around;
data:image/s3,"s3://crabby-images/c78e0/c78e0211125aa87b9f27497e3de00a0399d7813f" alt="图12:CSS Grid Layout 网格布局用法 图12:CSS Grid Layout 网格布局用法"
align-content: space-evenly;
data:image/s3,"s3://crabby-images/b2543/b254336c52d44c403fa381fa910d66595e5a1592" alt="图13:CSS Grid Layout 网格布局用法 图13:CSS Grid Layout 网格布局用法"
justify-content
和 align-content
属性都会在网格中对齐整个内容。
要对齐网格区域内的单个项目,可使用另一对对齐属性:justify-items
和 align-items
。这两个属性都可以有以下值:start
, end
, center
, baseline
(项目沿区域的基本网格线对齐)和stretch
(项目填满整个区域)。
本文文字及图片出自 https://www.hongkiat.com/blog/css-grid-layout-module/
你也许感兴趣的:
- 【外评】CSS masonry 砌体布局的替代建议
- 你需要知道的现代 CSS 技巧(2024 年春季版)
- 使用 :has() 作为 CSS 父选择器及其他更多内容
- 一个 Div 能做的事情
- 基于时间的 CSS 动画
- 【外评】请帮助我们实现 CSS grid 布局 Level 3,又称“砌体 Masonry”布局
- 最漂亮的 CSS 动画背景示例及源代码
- CSS Grid 网格布局中新引入的 Fr 单位用法教程
- 60+ CSS 搜索框代码 codepen 示例
- 响应式图片
你对本文的反应是: