css grid-area定义区域如何应用

来源:Java编程网作者:宋琮安头衔:草根站长
导读:本期聚焦于小伙伴创作的《css grid-area定义区域如何应用》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《css grid-area定义区域如何应用》有用,将其分享出去将是对创作者最好的鼓励。

CSS网格布局中的grid-area属性用于指定网格元素在网格容器中占据的区域,既可以直接使用预定义的区域名称,也可以通过指定网格线来定义区域的范围,是实现复杂网格布局的重要属性。

css grid-area定义区域如何应用

grid-area的基本语法

grid-area属性有以下几种常用的语法形式:

  • 单值形式:grid-area: <area-name>,使用grid-template-areas定义的区域名称
  • 四值形式:grid-area: <row-start> / <column-start> / <row-end> / <column-end>,分别指定区域的起始行、起始列、结束行、结束列
  • 简化形式:可以省略部分值,默认使用auto填充

配合grid-template-areas使用

这是最常见的使用场景,先通过grid-template-areas定义网格的整体区域划分,再给子元素设置grid-area指定对应的区域名称。

/* 容器样式 */
.grid-container {
    display: grid;
    grid-template-columns: 200px 1fr 150px;
    grid-template-rows: 80px 1fr 60px;
    /* 定义三个区域:头部、主体、侧边栏、底部 */
    grid-template-areas:
        "header header header"
        "sidebar main extra"
        "footer footer footer";
    height: 500px;
    gap: 10px;
}

/* 子元素指定区域 */
.header {
    grid-area: header;
    background-color: #f0f0f0;
}

.sidebar {
    grid-area: sidebar;
    background-color: #e0e0e0;
}

.main {
    grid-area: main;
    background-color: #d0d0d0;
}

.extra {
    grid-area: extra;
    background-color: #c0c0c0;
}

.footer {
    grid-area: footer;
    background-color: #b0b0b0;
}

对应的HTML结构如下:

<div class="grid-container">
    <div class="header">头部区域</div>
    <div class="sidebar">侧边栏</div>
    <div class="main">主体内容</div>
    <div class="extra">额外区域</div>
    <div class="footer">底部区域</div>
</div>

使用网格线定义区域范围

如果不想预先定义区域名称,也可以直接通过grid-area指定四条网格线来定义元素占据的范围,网格线可以是数字也可以是自定义的名称。

.grid-container-2 {
    display: grid;
    grid-template-columns: [col1] 100px [col2] 1fr [col3] 100px [col4];
    grid-template-rows: [row1] 60px [row2] 1fr [row3] 60px [row4];
    height: 400px;
    gap: 10px;
}

/* 元素占据第2行到第3行,第2列到第3列的区域 */
.content-box {
    grid-area: row2 / col2 / row3 / col3;
    background-color: #a0d8ef;
}

对应的HTML结构:

<div class="grid-container-2">
    <div class="content-box">使用网格线定义的区域</div>
</div>

grid-area的简写规则

当使用四值形式时,值的顺序严格按照行起始/列起始/行结束/列结束的顺序排列,如果某个方向的值使用auto,则会自动延伸到该方向的末尾。

/* 元素从第一行开始,第一列开始,延伸到最后一行,第二列结束 */
.auto-extend-box {
    grid-area: 1 / 1 / auto / 2;
    background-color: #ffcccb;
}

注意事项

  • 使用grid-template-areas定义区域时,每一行的区域数量需要和grid-template-columns的列数一致,否则布局会失效
  • 区域名称不能使用CSS的保留关键字,比如none、auto等
  • 如果同时设置了grid-area的区域名称和网格线范围,网格线范围的优先级更高
  • 网格区域的范围不能重叠,否则元素会按照层叠顺序显示,可能影响布局效果
grid-area属性不仅可以单独使用,还可以和grid-row、grid-column等属性配合,实现更灵活的网格布局调整,开发者可以根据实际布局需求选择合适的用法。

css_gridgrid-area网格布局修改时间:2026-06-21 16:00:14

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。