CSS 栅格布局(Grid)是一种全新的在 Web 上创建二维布局的方法。我们仅需几行 CSS,就可以创建一个之前不用 JavaScript 根本不可能实现的栅格布局。我们不需要任何插件或复杂的安装步骤,不需要繁琐的附加文件,同时也不需要局限于 12 列的栅格布局(译者注:指 Bootstrap 提供的 12 栅格系统)。
我们可以使用什么栅格?
简而言之:我们实际上可以使用几乎所有能够想到的栅格布局,并且还不限于此。我们可以自由地选择不同栅格的尺寸、大小和位置。你可以在栅格示例中找到最常见的带有标记的栅格的概述。
让我们从构建示例的 HTML 标记开始吧!
一个类名为 container
的 div
元素容纳了 5 个子 div
元素,或称之为项目(当然,可以比 5 个更多或者更少)。如果你愿意,我们可以直接从 CodePen 中的 HTML 和 CSS 标记代码入手。
<div class="container">
<div class="item color-1">item-1</div>
<div class="item color-2">item-2</div>
<div class="item color-3">item-3</div>
<div class="item color-4">item-4</div>
<div class="item color-5">item-5</div>
</div>
基础:在 CSS 中设置栅格和行列
在 CSS 中,我们可以通过 display: grid
定义将 .container
类的元素变为栅格布局。通过使用 grid-template-columns
,我们划分了所需的列(本例中将划分 5 列,每列设置为 250px)。通过使用 grid-template-rows
,我们可以设置行的高度(如果需要的话),本例中是 150px。完成以上步骤之后,我们就实现了第一个栅格布局!
.container {
display: grid;
grid-template-columns: 250px 250px 250px 250px 250px;
grid-template-rows: 150px;
}
/* 缩写:
grid-template-columns: repeat(5, 250px); */
设置间隔
我们可以使用 grip-gap
来设置每一项之间的间隔,也可以使用 column-gap
和 row-gap
分别设置水平和垂直的间隔。顺便提一句,我们可以使用所有通用单位,例如使用 px
用于设置固定的间隔,或使用 %
来设置自适应的间隔。
.container {
display: grid;
grid-template-columns: repeat(5, 250px);
grid-template-rows: 150px;
grid-gap: 30px;
}
使用 fr
自动填充剩余空间
这可是每一个设计师的梦想!我们可以使用 分数单位(Fractional Units)或简写 fr
,根据我们自己的想法分配可用空间!例如,在这里,我们将屏幕空间划分为 6 个部分。 第一列占用空间的 1/6 = 1fr,第二列 3/6 = 3fr,第三列 2/6 = 2fr。当然,我们也可以根据需要添加 grid-gap
。
.container {
display: grid;
grid-template-columns: 1fr 3fr 2fr;
}
现在所有的行都是自适应的!
混合使用 px
和 fr
构建自适应而又固定的列
px
和 fr
的按需同时使用可以让栅格适应可用的空间,这非常好用!
.container {
display: grid;
grid-template-columns: 300px 3fr 2fr;
}
排序上的绝对自由
私以为,最棒的是在栅格中,我们可以自由设置每一项所占用的尺寸!我们可以用 grid-column-start
设置起点,并用 grid-column-end
设置终点,或采用缩写方式 grid-column: startpoint / endpoint;
:
.container {
display: grid;
grid-template-columns: 1fr 3fr 2fr;
}
.item-1 {
grid-column: 1 / 4;
}
.item-5 {
grid-column: 3 / 4;
}
别被栅格线所迷惑,它们总是在第一项的开始!
同样适用于垂直或全区域的分布!
在这方面 CSS Grid 耀眼十足,表现出了对比 Bootstrap 和 Co 的优越性 —— 借助 grid-row
,每一项都可以定义任意的位置及宽度。正如我们将在下一个示例中看到的那样,这对于适应不同屏幕尺寸和设备具有绝对优势:
.container {
display: grid;
grid-template-columns: 1fr 3fr 2fr;
}
.item-2 {
grid-row: 1 / 3;
}
.item-1 {
grid-column: 1 / 4;
grid-row: 3 / 4;
}
想要适应不同的屏幕尺寸和设备?当然没问题!
CSS Grid 与常规栅格相比也具有明显的优势,根据屏幕大小,我们不仅可以通过媒体查询从自适应值切换到固定值,还可以调整整个项目的位置!
.container {
display: grid;
grid-template-columns: 250px 3fr 2fr;
}
.item-1 {
grid-column: 1 / 4;
}
.item-2 {
grid-row: 2 / 4;
}
@media only screen and (max-width: 720px) {
.container {
grid-template-columns: 1fr 1fr;
}
.item-1 {
grid-column: 1 / 3;
grid-row: 2 / 3;
}
.item-2 {
grid-row: 1 / 1;
}
}
浏览器支持
现在,所有现代浏览器(Safari、Chrome、Firefox、Edge)都原生地支持 CSS Grid。凭借 87.85% 的全球支持率(译者注:截止至译文发布时,支持率已达到 95.47%),CSS Grid 已经成为 Boostrap 和 Co 的替代品。
CSS 栅格的实践案例
- christinevallaure.com,,UX/UI 设计
- moonlearning.io,UX/UI 在线课程
- Slack,企业网站
- Medium,原文发布的地方
- Skyler Hughes,摄影网站
- Max Böck,前端开发者网站
- Design+Code,Web 设计师站点
- Hi Agency, Deck,模版页面
在你开始使用 Grid 之前
我想你可能还会喜欢我在 moonlearning.io 或完整的设计移交到开发课程 上发布的其它文章和课程(有关如何使用 Grid 的更多信息!)。
常见问题FAQ
- 免费下载或者VIP会员专享资源能否直接商用?
- 本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
- 提示下载完但解压或打开不了?
- 找不到素材资源介绍文章里的示例图片?
- 模板不会安装或需要功能定制以及二次开发?
发表评论
还没有评论,快来抢沙发吧!