CSS Grid 布局实战指南
CSS Grid 是 2018 年最令人兴奋的 CSS 特性之一,彻底改变了网页布局方式。
基础概念
定义网格
.container {
display: grid;
grid-template-columns: 200px 1fr 200px;
grid-template-rows: 60px 1fr 40px;
gap: 20px;
}
fr 单位
.container {
display: grid;
grid-template-columns: 1fr 2fr 1fr;
/* 第二列是其他两列的两倍宽 */
}
常见布局
圣杯布局
.layout {
display: grid;
grid-template-columns: 200px 1fr 200px;
grid-template-rows: 60px 1fr 60px;
grid-template-areas:
'header header header'
'nav main aside'
'footer footer footer';
min-height: 100vh;
}
.header { grid-area: header; }
.nav { grid-area: nav; }
.main { grid-area: main; }
.aside { grid-area: aside; }
.footer { grid-area: footer; }
响应式网格
.gallery {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
gap: 20px;
}
自适应卡片
.cards {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
gap: 1rem;
}
对齐
.container {
display: grid;
/* 水平和垂直居中 */
place-items: center;
/* 或分别设置 */
justify-items: center; /* 水平 */
align-items: center; /* 垂直 */
}
.content {
/* 内容对齐 */
justify-content: space-between;
align-content: center;
}
网格线
.item {
grid-column: 1 / 3; /* 从第1条线到第3条线 */
grid-row: 1 / 2;
}
/* 使用 span */
.item {
grid-column: span 2; /* 跨越2列 */
}
实用技巧
固定侧边栏
.layout {
display: grid;
grid-template-columns: 250px 1fr;
}
.sidebar {
position: sticky;
top: 0;
height: 100vh;
}
堆叠元素
.stack {
display: grid;
}
.stack > * {
grid-area: 1 / 1;
/* 所有子元素叠在同一位置 */
}
全宽背景
.section {
display: grid;
grid-template-columns: 1fr minmax(auto, 800px) 1fr;
}
.content {
grid-column: 2;
}
.full-width {
grid-column: 1 / -1;
}
与 Flexbox 配合
/* Grid 用于页面布局 */
.page {
display: grid;
grid-template-rows: auto 1fr auto;
}
/* Flexbox 用于组件内部 */
.nav {
display: flex;
justify-content: space-between;
}
浏览器支持
2018 年所有主流浏览器都已支持 CSS Grid。对于旧浏览器:
提供回退布局
使用 @supports 检测
CSS
返回首页