grid布局——从入门到放弃
基本知识
CSS grid 布局有两个核心组成部分:wrapper(网格容器,父元素)和items(网格项,子元素)。
基本属性
| 属性 | 含义 |
|---|---|
| display: grid | 网格布局(父元素设置) |
| grid-template-columns: 10px 10rem 10%; | 将列分为3份 |
| grid-template-rows: 10px 10rem 10%; | 将行分为3份 |
| grid-column-start: 1;grid-column-end: 4; | 盒子开始于第一条列线,结束于第四条列线 |
| grid-column: 1 / 4; | 以上的简写形式 |
| grid-row-start: 1;grid-row-end: 3; | 盒子开始于第一条行线,结束于第三条行线 |
| grid-row: 1 / 4; | 以上的代码简写 |

小案例
<div class="wrapper">
<div class="item1">1</div>
<div class="item2">2</div>
<div class="item3">3</div>
<div class="item4">4</div>
<div class="item5">5</div>
</div>
.wrapper {
width: 300px;
height: 300px;
background-color: #ddd;
text-align: center;
font-size: 30px;
margin: 0 auto;
/* 网格布局 */
display: grid;
/* 现在是3*3的网格 */
/* 将行分为3份 */
grid-template-columns: 33.3% 33.3% 33.3%;
/* 将列分为2份,不够或者多出都可以 */
grid-template-rows: 33.3% 33.3% 33.3%;
}
.item1 {
/* 开始于第一条行网格线,结束于第四条行网格线 */
grid-row-start:;
grid-row-end:;
background-color: red;
}
.item2 {
/* 简写:开始于第一条行网格线,结束于第三条行网格线 */
grid-column: 2/4;
background-color: green;
}
.item3 {
background-color: yellow;
}
.item4 {
grid-row: 2/4;
grid-column: 3/4;
background-color: pink;
}
.item5 {
grid-row: 3/4;
grid-column: 1/3;
background-color: purple;
}

继续挖掘
基本属性
| 属性 | 含义 |
|---|---|
| grid-template-columns: repeat(n, 1fr); | 将网格分为n列,1fr表示n分之一份 父元素 |
| grid-template-rows: 50px 400px 50px; | 分为3行,每一行的高度为50px 400px 50px。 父元素 |
| grid-template-areas: | 每一个网格项,你可以使用任意名称。“ . ”代表空白网格项。 父元素 |
| grid-area: | 网格区域(Grid Area)。 子元素 |
小案例

<div class="wrapper">
<div class="header">头部</div>
<div class="menu">菜单</div>
<div class="content">内容</div>
<div class="footer">底部</div>
</div>
.wrapper {
margin: 100px auto;
width: 600px;
background-color: #f5f5f5;
display: grid;
/* 分为12列,每一列为1fr */
grid-template-columns: repeat(12, 1fr);
grid-template-rows: 50px 400px 50px;
/* 12 * 3 = 36 个网页项 .为空白网格项*/
grid-template-areas:
"h h h h h h h h h h h h"
"m m c c c c c c c c c c"
"f f f f f f f f f f . .";
/* 网格边距 10px */
grid-gap: 10px;
}
.wrapper .header {
border-radius: 10px;
background-color: #bbf1bb;
/* 占据 名称为 h 的网格项 */
grid-area: h;
}
.wrapper .menu {
border-radius: 10px;
background-color: #fde886;
/* 占据 名称为 m 的网格项 */
grid-area: m;
}
.wrapper .content {
border-radius: 10px;
background-color: #8afcf9;
/* 占据 名称为 c 的网格项 */
grid-area: c;
}
.wrapper .footer {
border-radius: 10px;
background-color: #dfb8f8;
/* 占据 名称为 f 的网格项 */
grid-area: f;
}
还有一种书写方式实现该布局:
.wrapper {
margin: 100px auto;
background-color: #f5f5f5;
display: grid;
/* 分为12列,每一列为1fr */
grid-template-columns: repeat(12, 1fr);
grid-template-rows: 50px 400px 50px;
/* 网格边距 10px */
grid-gap: 10px;
}
.wrapper .header {
border-radius: 10px;
background-color: #bbf1bb;
/* 占据 名称为 h 的网格项 */
grid-area: 1/1/2/13;
}
.wrapper .menu {
border-radius: 10px;
background-color: #fde886;
/* 占据 名称为 m 的网格项 */
grid-area: 2/1/3/3;
}
.wrapper .content {
border-radius: 10px;
background-color: #8afcf9;
/* 占据 名称为 c 的网格项 */
grid-area: 2/3/3/13;
}
.wrapper .footer {
border-radius: 10px;
background-color: #dfb8f8;
/* 占据 名称为 f 的网格项 */
grid-area: 3/1/4/11;
}

与响应式结合使用
只需要在css中加入
/* 屏幕像素小于等于1000px时 */
@media screen and (max-width: 1000px) {
.wrapper {
grid-template-areas:
"m m m m m m h h h h h h"
"c c c c c c c c c c c c"
"f f f f f f f f f f f f";
}
}

补充理论
display: grid | inline-grid | subgrid;
grid :生成一个块级网格
inline-grid :生成一个内联网格
subgrid :如果你的网格容器本身是另一个网格的网格项(即嵌套网格),你可以使用这个属性来表示 grid-template-columns: repeat(3, 20px [col-start]) 5%;
等价于:grid-template-columns: 20px [col-start] 20px [col-start] 20px [col-start] 5%;
网格容器(Grid Container)
网格项(Grid item)
网格线(Grid Line)
网格轨道(Grid Track)
网格单元格(Grid Cell)
网格区域(Grid Area)
grid布局——从入门到放弃的更多相关文章
- grid布局快速入门
Grid布局快速入门 常用Grid布局属性介绍 下面从一个简单Grid布局例子说起.CSS Grid 布局由两个核心组成部分是 wrapper(父元素)和 items(子元素). wrapper 是实 ...
- CSS Grid布局入门
相信大家都比较熟悉flex布局了,最近有空研究了波grid布局,感觉虽然兼容性还不是太高,应用不是太普遍,但是功能非常强大.未来应该是grid+flex为主流,grid是二维布局,很灵活,适合整体构架 ...
- 带你入门 CSS Grid 布局
前言 三月中旬的时候,有一个对于 CSS 开发者来说很重要的消息,最新版的 Firefox 和 Chrome 已经正式支 CSS Grid 这一新特性啦.没错:我们现在就可以在最流行的两大浏览器上玩转 ...
- 你需要的Grid布局入门教程
一.Grid布局概述 首先,Grid 布局与 Flex布局 有一定的相似性,都可以指定容器内部多个项目的位置.但是,Grid 布局远比 Flex 布局强大! Flex 布局是轴线布局,只能指定&quo ...
- dotnet 从入门到放弃的 500 篇文章合集
本文是记录我从入门到放弃写的博客 博客包括 C#.WPF.UWP.dotnet core .git 和 VisualStudio 和一些算法,所有博客使用 docx 保存 下载:dotnet 从入门到 ...
- 学懂grid布局:这篇就够了(译)
上周发过一篇关于flex布局的文章,但发完之后我感觉我并没有写很多自己对flex布局的理解,因为原链接的作者的轮子实在是太强了,这里借用知乎大佬牛岱的话来说,当人家已经有足够好的轮子,你就不要试图,甚 ...
- 2018-8-10-dotnet-从入门到放弃的-500-篇文章合集
title author date CreateTime categories dotnet 从入门到放弃的 500 篇文章合集 lindexi 2018-08-10 19:16:52 +0800 2 ...
- WPF从入门到放弃系列第二章 XAML
本文是作者学习WPF从入门到放弃过程中的一些总结,主要内容都是对学习过程中拜读的文章的整理归纳. 参考资料 XAML 概述 (WPF):https://msdn.microsoft.com/zh-cn ...
- OkHttp框架从入门到放弃,解析图片使用Picasso裁剪,二次封装OkHttpUtils,Post提交表单数据
OkHttp框架从入门到放弃,解析图片使用Picasso裁剪,二次封装OkHttpUtils,Post提交表单数据 我们这片博文就来聊聊这个反响很不错的OkHttp了,标题是我恶搞的,本篇将着重详细的 ...
随机推荐
- JAVA String类常用方法
一.String类String类在java.lang包中,java使用String类创建一个字符串变量,字符串变量属于对象.java把String类声明的final类,不能有类.String类对象创建 ...
- nginx做维护页面
需求: 一个网站本来有好几个域名,然后也有好几个二级域名,现在停掉了,要求把所有的域名.二级域名,以及具体的文件请求,都指向一个维护页面. 1 单独在vhost里建一个conf文件 server { ...
- Kafka--Kafka简述
Kafka的诞生 Kafka最初是LinkedIn的一个内部基础设施系统.我们发现,虽然有很多数据库和系统可以用来存储数据,但在我们的架构里,刚好缺一个可以帮助处理持续数据流的组件. 我们希望能够把数 ...
- 百度easydl之图像分类构建是否佩戴口罩模型
2020-02-14 今天试了下百度esaydl的图像分类方面的功能,其优点是主需要上传自己的数据集,不需要关注模型训练,就可以得到相应的结果.最后得到的模型可以调用云api在本地进行运行. 网址:h ...
- 基于云开发开发 Web 应用(三):云开发相关数据调用
介绍 在完成了 UI 界面的实现后,接下来可以开始进行和云开发相关的数据对接.完成数据对接后,应用基础就打好了,接下来的就是发布上线以及一些小的 feature 的加入. 配置 在进行相关的配置调用的 ...
- Elasticsearch核心概念
Elasticsearch 核心概念 Cluster 代表一个集群, 集群中有多个节点, 其中一个为主节点, 该节点可以通过选举产生.(主从节点只针对于集群内部) 去中心化: 对于集群外来说无中心节点 ...
- vue学习(七)refs的使用
ref的使用只有在特殊的情况下使用 1.如果给标签添加ref,获取的就是真实的DOM节点2. 如果给子组件添加ref,获取的就是当前的子组件对象 例子: <div id="app&qu ...
- yagmail四行代码发送邮件
yagmail四行代码发送邮件 import yagmail # 链接邮箱服务器 yag = yagmail.SMTP(user="xxxx@163.com", password= ...
- python+selenium 发送邮件
import time from selenium import webdriver from selenium.webdriver import ChromeOptions from seleniu ...
- python --- request返回值乱码问题
1.分析 a)<HTTP权威指南>里第16章国际化里提到,如果HTTP响应中Content-Type字段没有指定charset,则默认页面是'ISO-8859-1'编码.一般现在页面编码都 ...