在css中如何用grid-auto-rows实现等高行

来源:中国站长站作者:冷风头衔:草根站长
导读:本期聚焦于小伙伴创作的《在css中如何用grid-auto-rows实现等高行》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《在css中如何用grid-auto-rows实现等高行》有用,将其分享出去将是对创作者最好的鼓励。

在CSS Grid布局体系中,grid-auto-rows属性用于定义那些被隐式创建的网格行的尺寸,当我们在网格容器中放置的子元素数量超过了显式定义的行数时,浏览器会自动创建新的行,这些行的高度就由grid-auto-rows来决定。如果要实现所有隐式行的等高效果,只需要给这个属性设置一个固定的长度值即可。

在css中如何用grid-auto-rows实现等高行

grid-auto-rows的基本语法

grid-auto-rows的常用取值包括固定长度、百分比、fr单位以及minmax()函数,要实现等高行,最常用的是固定长度取值,语法格式如下:

/* 设置所有隐式行高度为100px */
.grid-container {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-auto-rows: 100px;
}

实现等高行的具体步骤

1. 创建网格容器

首先需要将父元素设置为grid布局,同时定义列的规则,这里可以先不定义显式的行高,或者只定义部分显式行高,剩余的行由隐式规则控制。

/* 基础网格容器样式 */
.container {
    display: grid;
    /* 定义3列,每列等宽 */
    grid-template-columns: repeat(3, 1fr);
    /* 可选:定义显式行高,显式行也会保持等高 */
    grid-template-rows: repeat(2, 120px);
    /* 隐式行高度设置为120px,和显式行保持一致实现全等高 */
    grid-auto-rows: 120px;
    gap: 10px;
}

2. 添加网格子元素

子元素不需要额外设置高度,会自动填充到网格单元格中,当子元素数量超过显式定义的行能容纳的数量时,超出的子元素会进入隐式行,隐式行的高度由grid-auto-rows决定。

<div class="container">
    <div class="item">项目1</div>
    <div class="item">项目2</div>
    <div class="item">项目3</div>
    <div class="item">项目4</div>
    <div class="item">项目5</div>
    <div class="item">项目6</div>
    <div class="item">项目7</div>
</div>
/* 子元素基础样式 */
.item {
    background-color: #e0e0e0;
    padding: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
}

不同取值的等高效果差异

grid-auto-rows的不同取值会带来不同的等高效果,我们可以通过下面的表格对比:

取值类型效果说明适用场景
固定长度(如100px)所有隐式行高度固定为指定值,完全等高需要严格统一行高的场景
百分比(如20%)行高为网格容器高度的20%,容器高度固定时实现等高容器高度已知,需要按比例设置行高
fr单位(如1fr)隐式行会和显式行中的fr行分配剩余空间,高度一致需要隐式行和显式fr行等高的场景
minmax(100px, auto)隐式行最小高度为100px,内容超出时会自动增高,不再等高需要最小行高保证,内容可撑高行的场景

注意事项

  • grid-auto-rows只控制隐式创建的行,显式定义的行高由grid-template-rows控制,如果要所有行等高,需要把两个属性的取值设置为一致。
  • 如果子元素内容高度超过了grid-auto-rows设置的值,默认情况下内容会溢出,可给子元素设置overflow: hidden或者overflow: auto处理。
  • 当网格容器设置了grid-auto-flow: dense时,grid-auto-rows的等高规则依然生效,只是子元素的排列顺序会优化填充空白单元格。

完整示例代码

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>grid-auto-rows等高行示例</title>
    <style>
        .container {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            /* 显式定义2行,高度120px */
            grid-template-rows: repeat(2, 120px);
            /* 隐式行高度120px,和显式行保持一致 */
            grid-auto-rows: 120px;
            gap: 10px;
            width: 800px;
            margin: 20px auto;
        }
        .item {
            background-color: #4CAF50;
            color: white;
            padding: 10px;
            display: flex;
            align-items: center;
            justify-content: center;
            border-radius: 4px;
        }
    </style>
</head>
<body>
    <div class="container">
        <div class="item">项目1</div>
        <div class="item">项目2</div>
        <div class="item">项目3</div>
        <div class="item">项目4</div>
        <div class="item">项目5</div>
        <div class="item">项目6</div>
        <div class="item">项目7</div>
        <div class="item">项目8</div>
    </div>
</body>
</html>

上面的示例中,前6个项目会填充到显式定义的2行3列中,第7、8个项目会进入隐式行,隐式行的高度和显式行都是120px,最终所有行的高度完全一致,实现了等高行的效果。

CSS Gridgrid-auto-rows等高行布局网格布局修改时间:2026-06-19 14:24:19

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