css网格布局Grid

一、网格布局适应场景

当涉及到的布局是二维布局(元素不止一行或者一列)且比较复杂的时候,可以用网格布局,看下面的一个例子:

上图上一个四行三列的网格,布局相对比较复杂。如果你用别的布局方案,例如:绝对定位,flex,float等等,实现起来都很麻烦,但是你用了网格布局,情况就好多了。文章最后会附上上面示例的代码。

二、关键属性详解

1. 容器属性

属性 作用 示例
display: grid 启用网格布局 .container { display: grid; }
grid-template-columns 定义列的轨道大小(支持固定值、百分比、fr 单位、minmax() 等) grid-template-columns: 100px 1fr 2fr;
grid-template-rows 定义行的轨道大小 grid-template-rows: repeat(3, 100px);
gap 设置行和列的间距(兼容旧版需用 grid-row-gapgrid-column-gap .container { gap: 10px; }
grid-template-areas 通过命名区域定义布局 grid-template-areas: "header header" "sidebar main";
grid-auto-flow 控制自动放置算法(row/column/dense grid-auto-flow: column dense;

2. 网格项属性

属性 作用 示例
grid-column 定义网格项的列范围(起始线/结束线或 span 跨度) grid-column: 2 / span 3;(从第2列跨越3列)
grid-row 定义网格项的行范围 grid-row: 1 / 3;(从第1行跨越2行)
grid-area 简写属性,合并 grid-rowgrid-column,或直接引用命名区域 grid-area: header;(分配到命名区域)
justify-self 控制网格项在单元格内的水平对齐方式 justify-self: end;
align-self 控制网格项在单元格内的垂直对齐方式 align-self: center;

三、常见布局场景

1. 基础网格

css 复制代码
.container {

display: grid;

grid-template-columns: repeat(3, 1fr); /* 3列等宽 */

grid-template-rows: repeat(2, 100px); /* 2行,每行100px */

gap: 10px;

}

效果:3列×2行的网格,所有单元格大小相同。

2. 跨行/跨列

css 复制代码
.item-span {
grid-column: 2 / 4; /* 跨越第2、3列 */
grid-row: 1 / 3; /* 跨越第1、2行 */
}

效果:一个网格项占据2行×2列的区域。

3. 命名网格区域

css 复制代码
.container {
display: grid;
grid-template-areas:
"header header header"
"sidebar main main"
"footer footer footer";
}


.header { grid-area: header; }
.sidebar { grid-area: sidebar; }

效果:通过名称直观分配布局区域。

4. 响应式网格

css 复制代码
.container {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

效果:自动填充容器宽度,每列最小200px,剩余空间均分。


四、与 Flexbox 的对比

特性 Grid Layout Flexbox
维度 二维布局(行+列) 一维布局(行或列)
适用场景 复杂页面结构(如仪表盘、表格) 一维布局(如导航栏、卡片组)
对齐控制 支持单元格内和单元格间的对齐 仅支持容器内子项的对齐
嵌套复杂度 减少嵌套,直接定义二维结构 可能需要多层嵌套实现复杂布局

五、第一部分示例代码

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        *{
            margin: 0;
            padding: 0;
        }
        .container {
            width: 80%;
            height: 60vh;
            background-color: pink;
            padding: 2px;
            display: grid;
            row-gap: 2px;
            column-gap:5px;
            grid-template-columns: repeat(3, 1fr);
            grid-template-rows: repeat(4, 1fr)
        }

        .item {
            border: 1px solid #000;
        }

        .one {
            background-color: blue;
            grid-column: 2 / span 2;
        }
        .two {
            background-color: red;
            grid-column: 3;
            grid-row: 2 / span 2;
        }
        .three {
            background-color: green;
            grid-column: 1 / span 2;
            grid-row: 1 / span 2;
        }
    </style>
</head>
<body>
    <div class="container">
        <div class="item three">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 two">6</div>
        <div class="item">7</div>
        <div class="item">8</div>
        <!-- <div class="item">9</div> -->
        <div class="item">10</div>
        <div class="item one">11</div>
        <!-- <div class="item">12</div> -->
    </div>
</body>
</html>
相关推荐
秋天爱美丽4 小时前
css实现圆角+边框渐变+背景半透明
前端·css
XboxYan9 小时前
借助CSS实现自适应屏幕边缘的tooltip
前端·css
艾小码10 小时前
CSS粘性定位失效?深度解析 position: sticky 的陷阱与解决方案
前端·css
cos10 小时前
FE Bits Vol.3|CSS attr() 类型化进化,PostCSS 复盘 12 年
前端·css·aigc
全宝10 小时前
【前端特效系列】css+js实现聚光灯效果
javascript·css·html
rannn_1111 天前
【Javaweb学习|黑马笔记|Day1】初识,入门网页,HTML-CSS|常见的标签和样式|标题排版和样式、正文排版和样式
css·后端·学习·html·javaweb
小离a_a1 天前
使用原生css实现word目录样式,标题后面的...动态长度并始终在标题后方(生成点线)
前端·css
郭优秀的笔记1 天前
抽奖程序web程序
前端·css·css3
布兰妮甜1 天前
CSS Houdini 与 React 19 调度器:打造极致流畅的网页体验
前端·css·react.js·houdini
小小愿望1 天前
移动端浏览器中设置 100vh 却出现滚动条?
前端·javascript·css