0

0

CSS Grid构建圣杯布局_html/css_WEB-ITnose

php中文网

php中文网

发布时间:2016-06-24 11:21:36

|

1567人浏览过

|

来源于php中文网

原创

css 网格布局模块 ,虽然现在仍处于编译者的草案之中但是即将定稿。我们现在可以在 一些浏览器中 进行测试并可以检测其潜在的bug。

有关于CSS Grid布局模块更多的教程,可以点击这里阅读。

CSS 网格布局是真的很复杂,相较于Flexbox 更是如此。它具有17个新属性并且在如何使用CSS书写方面介绍了很多新概念。为了尝试如何使用萦绕在我脑海中的这些新规范,我决定创建一个 圣杯布局 尝试新规范工作原理。

什么是圣杯布局?

圣杯布局 是一种包括页眉、页脚和一个包含两个左右边栏的主内容区的网页布局。其布局遵循以下规则:

  • 固定宽度侧边栏自适应主内容区域
  • 中间一列应该在 标记中最先出现 ,早于两个侧边栏(但在页眉后)
  • 不管三列中包含的是什么,都应该具有 相同的高度
  • 页脚应该总是处于 浏览器视窗的底部 ,即使内容不能填满视区高度
  • 布局应该是 响应 的,在小视窗中所有的部分应该在一列中显示

大家都知道如果不使用hacks这是很难用CSS来实现的。

立即学习前端免费学习笔记(深入)”;

CSS Grid解决方案

下面是我用 CSS 网格布局想出的的解决方案。第一,标记--

      
Title
Content
Footer

CSS样式的代码只有 31 行:

.hg__header {    grid-area: header;}.hg__footer {    grid-area: footer;}.hg__main {    grid-area: main;}.hg__left {    grid-area: navigation;}.hg__right {    grid-area: ads;}.hg {    display: grid;    grid-template-areas: "header header header"                         "navigation main ads"                         "footer footer footer";    grid-template-columns: 150px 1fr 150px;    grid-template-rows: 100px                         1fr                        30px;    min-height: 100vh;}@media screen and (max-width: 600px) {    .hg {        grid-template-areas: "header"                             "navigation"                             "main"                             "ads"                             "footer";        grid-template-columns: 100%;        grid-template-rows: 100px                             50px                             1fr                            50px                             30px;    }}

Toolplay
Toolplay

一站式AI应用聚合生成平台

下载

把它分解

如前所述,CSS 网格布局可能非常复杂。然而,创建此布局我只用 17 个新属性中的4个:

  • grid-area
  • grid-template-areas
  • grid-template-columns
  • grid-template-rows

使用这些 CSS 网格属性创建圣杯布局可以分解成五个步骤。

定义网格

我们想要做的第一件事是定义网格区域,创建网格时我们可以引用它们的别名。这里用到的是 grid-area 属性。

.hg__header {    grid-area: header;}.hg__footer {    grid-area: footer;}.hg__main {    grid-area: main;}.hg__left {    grid-area: navigation;}.hg__right {    grid-area: ads;}

然后,使用 grid-template-areas 属性,我们可以真正直观的指定网格的布局。 grid-template-areas 属性接受一个以空格分隔的字符串。每个字符串表示一行,利用每个字符串,我们就可以获取以一个空格分隔的网格区域列表值,每一个值均定义网格区域的一列。所以如果我们要跨越两列区域,我们需要定义两次。

在我们圣杯布局中有 3 列 3 行。页眉和页脚行跨越 3 列,其他跨越 1 列。

.hg {    display: grid;    grid-template-areas: "header header header"                         "navigation main ads"                         "footer footer footer";}

利用此标记我们可以得到以下结果。

定义列宽

接下来,我们想要定义列的宽度。这里我们利用 grid-template-columns 属性定义列的宽度。此属性接受一个空格分隔的宽度列表,每一个值均表示网格中的一列。因为在我们的布局中有 3 列,我们可以指定 3 个宽度:

grid-template-columns: [column 1 width]  [column 2 width]  [column 3 width];  

对于圣杯布局,我们想要将 2 个侧栏的宽度设置为 150px 。

.hg {    grid-template-columns: 150px  [column 2 width] 150px;}

对于中间列,我们想要其占据其余的全部空间。这里我们可以使用新单位 fr 。这个单位表示网格中剩余的全部空间。在我们的例子表示网格减去 300px (两个侧边栏的宽度)后的宽度。

.hg {    grid-template-columns: 150px 1fr 150px;}

设置完网格列之后, 布局看起来如下所示-

定义行高

接下来,我们就要定义行的高度了。类似于我们用 grid-template-columns 属性定义列的宽度,我们使用 grid-template-rows 属性定义行高。此属性也是接受以空格分隔的一行高度列表。虽然我们可以把它写在同一行中,但是我认为为了使其更加清晰直观将一值写一行。

.hg {    grid-template-rows: 100px                        1fr                        30px;}

所以布局中的页眉高度为 100px ,页脚高度为 30px ,中间一行(主要内容和两个侧边栏)占据 .hg 元素中其余的可用空间。

定位页脚

在圣杯布局中,即使页面内容十分稀疏,我们也想要页脚总是处于视窗的底部。要实现这一目标,我们可以在 .hg 元素中设置一个最小的视窗高度。

.hg {    min-height: 100vh;}

因为我们将中间一列的宽度和高度设置为占据 .hg 元素的剩余空间,所以它就会适应于整个屏幕。

响应式

最后,我们想要布局具有响应性。在较小的设备上所有网格项应该一个接一个的以单列显示。为此,我们需要重新定义之前的- grid-template-areas 、 grid-template-columns 和 grid-template-rows 3个属性.

首先,我们想要所有的网格项按照特定顺序在一列中显示:

@media screen and (max-width: 600px) {    .hg {        grid-template-areas: "header"                             "navigation"                             "main"                             "ads"                             "footer";    }}

接下来,我们想要所有的网格项跨越整个宽度:

@media screen and (max-width: 600px) {    .hg {        grid-template-columns: 100%;    }}

最后,我们需要重置每个行的高度。除了 main 之外的所有行都有一个已定义的高度:

@media screen and (max-width: 600px) {    .hg {        grid-template-rows: 100px /* Header */                            50px /* Navigation */                            1fr /* Main Content */                            50px /* Ads */                            30px; /* Footer */    }}

就是这样!你可以看看 这里的演示 以及 源码 (nb:你可能需要在浏览器中启用网络功能才可以看到)。

浏览器支持

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

391

2026.01.28

包子漫画在线官方入口大全
包子漫画在线官方入口大全

本合集汇总了包子漫画2026最新官方在线观看入口,涵盖备用域名、正版无广告链接及多端适配地址,助你畅享12700+高清漫画资源。阅读专题下面的文章了解更多详细内容。

135

2026.01.28

ao3中文版官网地址大全
ao3中文版官网地址大全

AO3最新中文版官网入口合集,汇总2026年主站及国内优化镜像链接,支持简体中文界面、无广告阅读与多设备同步。阅读专题下面的文章了解更多详细内容。

233

2026.01.28

php怎么写接口教程
php怎么写接口教程

本合集涵盖PHP接口开发基础、RESTful API设计、数据交互与安全处理等实用教程,助你快速掌握PHP接口编写技巧。阅读专题下面的文章了解更多详细内容。

8

2026.01.28

php中文乱码如何解决
php中文乱码如何解决

本文整理了php中文乱码如何解决及解决方法,阅读节专题下面的文章了解更多详细内容。

13

2026.01.28

Java 消息队列与异步架构实战
Java 消息队列与异步架构实战

本专题系统讲解 Java 在消息队列与异步系统架构中的核心应用,涵盖消息队列基本原理、Kafka 与 RabbitMQ 的使用场景对比、生产者与消费者模型、消息可靠性与顺序性保障、重复消费与幂等处理,以及在高并发系统中的异步解耦设计。通过实战案例,帮助学习者掌握 使用 Java 构建高吞吐、高可靠异步消息系统的完整思路。

10

2026.01.28

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

24

2026.01.27

拼多多赚钱的5种方法 拼多多赚钱的5种方法
拼多多赚钱的5种方法 拼多多赚钱的5种方法

在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。

124

2026.01.26

edge浏览器怎样设置主页 edge浏览器自定义设置教程
edge浏览器怎样设置主页 edge浏览器自定义设置教程

在Edge浏览器中设置主页,请依次点击右上角“...”图标 > 设置 > 开始、主页和新建标签页。在“Microsoft Edge 启动时”选择“打开以下页面”,点击“添加新页面”并输入网址。若要使用主页按钮,需在“外观”设置中开启“显示主页按钮”并设定网址。

98

2026.01.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Bootstrap 4 中文开发手册
Bootstrap 4 中文开发手册

共0课时 | 0人学习

CSS深入理解之border视频教程
CSS深入理解之border视频教程

共7课时 | 1.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号