当前位置:首页 > 文章列表 > 文章 > 前端 > CSS网格布局中,grid-template是一个简写属性,用于设置grid-template-rows、grid-template-columns和grid-template-areas。它可以帮助你快速定义网格的行、列和区域布局。语法格式:grid-template:<grid-template-rows>/<grid-template-columns>;或者使用区域:

CSS网格布局中,grid-template是一个简写属性,用于设置grid-template-rows、grid-template-columns和grid-template-areas。它可以帮助你快速定义网格的行、列和区域布局。语法格式:grid-template:<grid-template-rows>/<grid-template-columns>;或者使用区域:

2025-07-13 17:36:34 0浏览 收藏

CSS网格布局的核心属性`grid-template`,是定义网格结构的关键。通过一行代码,即可同时设定网格的行、列以及命名区域,极大地简化了复杂布局的实现。要使用`grid-template`,首先需将容器设置为`display: grid`或`inline-grid`。`grid-template`实际上是`grid-template-rows`、`grid-template-columns`和`grid-template-areas`的简写形式,通过`/`分隔行和列的定义。它支持`fr`单位实现弹性空间分配,以及`minmax()`函数设定轨道尺寸范围,从而提升响应式设计能力。结合媒体查询,`grid-template`能轻松实现不同屏幕尺寸下的布局切换,增强布局的灵活性与可维护性。

grid-template 是CSS Grid布局的核心复合属性,它通过一行代码同时定义网格的行、列结构和命名区域。1. 使用时需先设置容器为 display: grid 或 inline-grid;2. 它是 grid-template-rows、grid-template-columns 和 grid-template-areas 的简写形式;3. 语法上,/ 前定义行结构与区域名称,/ 后定义列结构;4. 支持 fr 单位实现弹性空间分配,minmax() 函数设定轨道尺寸范围,从而提升响应式设计能力;5. 可结合媒体查询实现不同屏幕尺寸下的布局切换,极大增强了布局的灵活性与可维护性。

CSS如何创建网格布局_grid_template配置

grid-template 是CSS Grid布局里一个非常核心且功能强大的复合属性。它允许你在一行代码里同时定义网格的行(rows)、列(columns)结构以及命名区域(areas)。简单来说,它就像一个总设计师,一次性把整个页面的骨架和区域划分都确定下来,让布局变得异常直观和可读,远比我们以前用浮动或者flexbox来做复杂布局要省心得多。

CSS如何创建网格布局_grid_template配置

解决方案: 要创建网格布局并配置 grid-template,你首先需要将容器元素设置为 display: griddisplay: inline-grid。接着,就可以使用 grid-template 属性来定义网格的结构了。

grid-template 实际上是 grid-template-rowsgrid-template-columnsgrid-template-areas 这三个属性的简写。它的语法结构大致是这样的:

CSS如何创建网格布局_grid_template配置
.container {
  display: grid;
  grid-template:
    [row1-start] "header header header" 100px [row1-end]
    [row2-start] "nav main aside" auto [row2-end]
    [row3-start] "footer footer footer" 50px [row3-end]
    / 1fr 2fr 1fr; /* 这里的 / 后面是列定义 */
}

让我来拆解一下这个例子,我个人觉得这样写是把 grid-template 的威力展现得淋漓尽致:

  1. 行定义与区域命名:/ 符号之前的部分,每一对双引号代表一行,里面的字符串是该行中各个单元格对应的区域名称。比如 "header header header" 意味着这一行有三个单元格,它们都属于 header 区域。你可以用 . 来表示一个空的单元格。 行的高度(如 100px, auto, 50px)紧随其后。 方括号 [row1-start] 是可选的行线名称,方便后续定位。

    CSS如何创建网格布局_grid_template配置
  2. 列定义:/ 符号之后的部分定义了网格的列结构。比如 1fr 2fr 1fr 定义了三列,宽度比例为 1:2:1。这里可以使用各种长度单位(px, em, rem, %),也可以使用 fr 单位(fractional unit,表示可用空间的一份),minmax() 函数,甚至 repeat() 函数。

示例:一个经典的页面布局

<div class="grid-container">
  <header>Header</header>
  <nav>Nav</nav>
  <main>Main Content</main>
  <aside>Aside</aside>
  <footer>Footer</footer>
</div>
.grid-container {
  display: grid;
  /*
   * 定义三行:header行高100px,main行自适应,footer行高50px
   * 定义三列:左侧导航1份,中间主内容2份,右侧边栏1份
   * 并为每个区域命名
   */
  grid-template:
    "header header header" 100px
    "nav    main   aside" auto
    "footer footer footer" 50px
    / 1fr 2fr 1fr; /* 列的定义 */

  gap: 10px; /* 网格间距 */
  height: 100vh; /* 方便看效果 */
}

/* 将子元素放置到对应的命名区域 */
header { grid-area: header; background-color: #f0f0f0; padding: 10px; }
nav { grid-area: nav; background-color: #e0e0e0; padding: 10px; }
main { grid-area: main; background-color: #d0d0d0; padding: 10px; }
aside { grid-area: aside; background-color: #c0c0c0; padding: 10px; }
footer { grid-area: footer; background-color: #b0b0b0; padding: 10px; }

通过这种方式,整个页面的宏观布局一眼就能看明白,维护起来也方便很多。我个人在做响应式布局时,经常会结合媒体查询来调整 grid-template 的值,简直是神器。

grid-templatefr 单位和 minmax() 函数如何提升布局弹性?

在我看来,fr 单位和 minmax() 函数是 grid-template 乃至整个CSS Grid布局中最具革命性的特性之一,它们直接解决了传统布局中弹性与固定尺寸难以兼顾的痛点。

fr (fractional unit) 代表“一份”可用空间。它的强大之处在于,它会自动计算并分配容器内剩余的空间。举个例子,如果你有三列,定义为 1fr 2fr 1fr,这意味着第一列和第三列各占一份可用空间,而第二列则占据两份。如果总共有 4 份,那么第二列就会是总宽度的 50%。这比百分比灵活得多,因为它是在扣除固定尺寸元素(比如 px 单位的侧边栏)后,再来分配剩余空间。我经常用它来做主内容区域的自适应宽度,简直是省心。

minmax(min, max) 函数则更进一步,它允许你为网格轨道(行或列)设置一个尺寸范围。这意味着你可以说:“这个列的宽度最小是 200px,最大是 1fr。” 当可用空间不足 200px 时,它会保持 200px(可能出现溢出);当空间充足时,它会按 1fr 的比例进行分配。这种弹性与限制的结合,对于创建真正健壮和响应式的布局至关重要。

想象一下,你有一个侧边栏,你希望它最小宽度是 250px,但如果屏幕足够宽,它也可以扩展到占据总宽度的 0.25fr。这时你就可以写 minmax(250px, 0.25fr)。这种能力让我觉得在处理不同屏幕尺寸时的布局策略变得异常清晰和直接,不再需要复杂的JS计算或者嵌套多层flexbox来模拟。

grid-templategrid-template-areas 有何关联?

实际上,grid-template-areasgrid-template 这个大属性里的一部分,或者说,grid-template 包含了 grid-template-areas 的功能。当我第一次接触到 grid-template 的时候,我发现它把行、列的定义和区域的命名巧妙地融合在了一起,这种做法简直是天才。

grid-template-areas 单独使用时,你需要先用 grid-template-rowsgrid-template-columns 定义好网格结构,然后才能用 grid-template-areas 来放置元素。例如:

.container {
  display: grid;
  grid-template-rows: 100px auto 50px;
  grid-template-columns: 1fr 2fr 1fr;
  grid-template-areas:
    "header header header"
    "nav main aside"
    "footer footer footer";
}

grid-template 的美妙之处在于,它把这些都整合到了一起。你可以在定义行和列的同时,直接用字符串字面量来“画”出你的布局区域。这就好像你拿着笔在纸上画草图一样,非常直观。

.container {
  display: grid;
  grid-template:
    "header header header" 100px /* 定义第一行是header区域,高100px */
    "nav main aside" auto         /* 定义第二行是nav, main, aside区域,高自适应 */
    "footer footer footer" 50px   /* 定义第三行是footer区域,高50px */
    / 1fr 2fr 1fr;                /* 最后定义三列的宽度比例 */
}

这种集成方式,在我看来,大大提升了代码的可读性和维护性。当你需要调整布局时,你只需要看 grid-template 这一行或这几行代码,就能清晰地看到整个页面的骨架是如何组织的。特别是当布局比较复杂时,这种视觉化的定义方式能有效避免出错,并且让团队成员之间更容易理解布局意图。它把布局的“意图”和“实现”融合得非常好。

在实际项目中,grid-template 还有哪些高级用法或注意事项?

在实际项目里,grid-template 的应用远不止基础布局那么简单。我发现它的一些“高级”用法或者说一些需要注意的细节,能让你的布局更加灵活和健壮。

一个很常见的场景是响应式设计。虽然前面提到了用媒体查询改变 grid-template 的值,但更进一步,你可以利用它来彻底改变不同屏幕尺寸下的布局结构。比如,在桌面端可能是三列布局,到了移动端,你可能想让它们变成单列堆叠,这时只需要在媒体查询里重写 grid-template 即可:

/* 桌面端 */
.grid-container {
  grid-template:

到这里,我们也就讲完了《CSS网格布局中,grid-template是一个简写属性,用于设置grid-template-rows、grid-template-columns和grid-template-areas。它可以帮助你快速定义网格的行、列和区域布局。语法格式:grid-template:/;或者使用区域:grid-template:[row-names]/[column-names];或者同时设置行、列和区域:grid-template:[row-names]/[column-names][area-names];示例一:基本行和列设置.grid-container{display:grid;grid-template:100px200px/1fr2fr;}这表示:行高为100px和200px列宽为1fr和2fr示例二:使用命名区域.grid-container{display:grid;grid-template:"headerheader"100px"sidebarmain"200px/1fr2fr;}这里:定义了三行(第一行高度为100px,第二行200px,第三行》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

Go语言io.Reader.Read使用指南与避坑技巧Go语言io.Reader.Read使用指南与避坑技巧
上一篇
Go语言io.Reader.Read使用指南与避坑技巧
Golang反射机制与reflect包使用详解
下一篇
Golang反射机制与reflect包使用详解
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    511次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    498次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • AI边界平台:智能对话、写作、画图,一站式解决方案
    边界AI平台
    探索AI边界平台,领先的智能AI对话、写作与画图生成工具。高效便捷,满足多样化需求。立即体验!
    411次使用
  • 讯飞AI大学堂免费AI认证证书:大模型工程师认证,提升您的职场竞争力
    免费AI认证证书
    科大讯飞AI大学堂推出免费大模型工程师认证,助力您掌握AI技能,提升职场竞争力。体系化学习,实战项目,权威认证,助您成为企业级大模型应用人才。
    421次使用
  • 茅茅虫AIGC检测:精准识别AI生成内容,保障学术诚信
    茅茅虫AIGC检测
    茅茅虫AIGC检测,湖南茅茅虫科技有限公司倾力打造,运用NLP技术精准识别AI生成文本,提供论文、专著等学术文本的AIGC检测服务。支持多种格式,生成可视化报告,保障您的学术诚信和内容质量。
    559次使用
  • 赛林匹克平台:科技赛事聚合,赋能AI、算力、量子计算创新
    赛林匹克平台(Challympics)
    探索赛林匹克平台Challympics,一个聚焦人工智能、算力算法、量子计算等前沿技术的赛事聚合平台。连接产学研用,助力科技创新与产业升级。
    660次使用
  • SEO  笔格AIPPT:AI智能PPT制作,免费生成,高效演示
    笔格AIPPT
    SEO 笔格AIPPT是135编辑器推出的AI智能PPT制作平台,依托DeepSeek大模型,实现智能大纲生成、一键PPT生成、AI文字优化、图像生成等功能。免费试用,提升PPT制作效率,适用于商务演示、教育培训等多种场景。
    567次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码