一、Grid布局概述

首先,Grid 布局与 Flex布局 有一定的相似性,都可以指定容器内部多个项目的位置。但是,Grid 布局远比 Flex 布局强大!

  • Flex 布局是轴线布局,只能指定"项目"针对轴线的位置,可以看作是一维布局
  • Grid 布局则是将容器划分成"行"和"列",产生单元格,然后指定"项目所在"的单元格,可以看作是二维布局

二、基本概念

(1)容器和项目

采用网格布局的区域,称为"容器"(container)。容器内部采用网格定位的子元素,称为"项目"(item)。

<div class="container">
<div class="item"><p>1</p></div>
<div class="item"><p>2</p></div>
<div class="item"><p>3</p></div>
</div>

上述代码中,如果.container设置了display:grid属性,则它就是网格布局容器 ,其内部孩子节点.item就称为项目

注意:项目只能是容器的顶层子元素,不包含项目的子元素,所以p元素不是项目。Grid 布局只对项目生效

(2)行和列

容器里面的水平区域称为"行"(row),垂直区域称为"列"(column),行和列的交叉区域,称为"单元格"(cell)

(3)网格线

划分网格的线,称为"网格线"(grid line)。水平网格线划分出行,垂直网格线划分出列。

这就是一个4行4列的网格,存在5根水平网格线和5根垂直网格线

三、容器属性

定义在容器上面的属性,称为容器属性

(1)display

  • display: grid指定一个容器采用块级网格布局
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<style type="text/css">
.container{
display: grid;
grid-template-columns: 50px 50px;
grid-template-rows: 50px 50px;
border: 3px solid #9575CD;
}
.item {
font-size: 2em;
text-align: center;
border: 1px solid #e5e4e9;
}
.item-1 {
background-color: #aaaaff;
} .item-2 {
background-color: #1bf6d5;
} .item-3 {
background-color: #56a982;
} .item-4 {
background-color: #6072c2;
}
</style>
</head>
<body>
<span>辅助元素1</span>
<div class="container">
<div class="item item-1">1</div>
<div class="item item-2">2</div>
<div class="item item-3">3</div>
<div class="item item-4">4</div>
</div>
<span>辅助元素2</span>
</body>
</html>

  • display: inline-grid指定一个容器采用行内网格布局
.container{
display: inline-grid;
grid-template-columns: 50px 50px;
grid-template-rows: 50px 50px;
border: 3px solid #9575CD;
}

特别注意:设为网格布局以后,容器子元素(项目)的floatdisplay: inline-blockdisplay: table-cellvertical-aligncolumn-*等设置都将失效。

.item {
font-size: 2em;
text-align: center;
border: 1px solid #e5e4e9;
float: right; /* 设置所有项目右浮动(失效) */
}

从结果可以看出,子项目并没有右浮动到最右边(失效)

(2)grid-template-columns 和 grid-template-rows

grid-template-columns 属性定义每一列的列宽

grid-template-rows 属性定义每一行的行高

  • 使用绝对单位划分
.container{
display: grid;
grid-template-columns: 50px 50px; /* 定义两列,列宽为50px */
grid-template-rows: 50px 50px; /* 定义两行,行高为50px */
border: 3px solid #9575CD;
}

  • 使用百分比划分
.container{
display: grid;
grid-template-columns: 20% 10%; /* 定义两列,列宽为20% 10% */
grid-template-rows: 40% 30%; /* 定义两行,行高为40% 30% */
border: 3px solid #9575CD;
}

  • repeat()函数

从上面例子可以看出,存在重复写同样的值,如果网格很多会显得十分臃肿,这时可以使用reapeat()函数来优化

.container{
display: grid;
grid-template-columns: repeat(2,150px);
grid-template-rows: repeat(2,50px);
}

reapeat()函数接收两个值,第一个值为重复次数,第二个值为需要重复的值。另外,重复某种模式也是可以的:

.container{
display: grid;
grid-template-columns: repeat(2,150px 50px);
}

repeat(2,150px 50px):表示重复了模式,定义了4列,第一列和第三列为150px ,第二列和第四列为50px

  • auto-fill 关键字

auto-fill值用于自动填充,当单元格的大小需要固定不变,容器大小不确定时使用

.container{
display: grid;
grid-template-columns: repeat(auto-fill,50px);
}

repeat(auto-fill,50px):表示设置每列宽度为50px自动填充,直到容器不能放置更多的列,然后换行排列(例子如下):

.container{
display: grid;
width: 150px;
border: 1px dashed red;
grid-template-columns: repeat(auto-fill,50px);
}

(换行排列)

  • fr 关键字

fr关键字用于表示比例关系(fraction 的缩写,意为"片段”)

.container{
display: grid;
grid-template-columns: 1fr 5fr;
}

1fr 5fr:表示设置两列,列宽分别为1fr5fr ,第二列是第一列的5倍

另外,fr可以与绝对长度的单位结合使用:

.container{
display: grid;
grid-template-columns:50px 1fr 2fr;
}

50px 1fr 2fr:表示第一列宽度为50px,第二列宽度时第三列的一半

  • auto 关键字

auto关键字表示由浏览器决定自己的长度

.container{
display: grid;
grid-template-columns: 50px auto 50px auto;
}

50px auto 50px auto表示第二列和第四列自动填充,相当于flex:1

(3)row-gap 和 column-gap

row-gap属性设置 行与行 的间隔(行间距)

column-gap属性设置 列与列 的间隔(列间距)

.container{
display: grid;
grid-template-columns: 50px 50px;
grid-template-rows: 50px 50px;
row-gap: 20px; /* 行间距为20px */
column-gap: 10px; /* 列间距为10px */
}

另外,这两个属性有个复合属性:gap

gap语法:

gap: <row-gap> <column-gap>;
.container{
row-gap: 20px;
column-gap: 10px;
/* 等同于 */
gap: 20px 10px;
}

注意:如果gap只有一个值,默认第二个值等于第一个值

普及:这三个属性名原来是由前缀grid-的,目前最新标准已经将grid-前缀删除,但还是可以用~

(4)grid-auto-flow

划分网格后,容器中的子元素默认按照“先行后列”的顺序自动放置在每一个网格中(先填满第一行,在开始第二行)

grid-auto-flow属性自己规定排列顺序,默认值为row,可以设置column,类似于flex-direction

.container{
display: grid;
grid-template-columns: 50px 50px;
grid-template-rows: 50px 50px;
grid-auto-flow: row; /* 默认值 */
}

.container{
display: grid;
grid-template-columns: 50px 50px;
grid-template-rows: 50px 50px;
grid-auto-flow: column; /* 先列后行 */
}

(5)justify-items 和 align-items

justify-items属性设置单元格内容水平位置(左中右)

align-items属性设置单元格内容垂直位置(上中下)

语法:

.container {
justify-items: start | end | center | stretch;
align-items: start | end | center | stretch;
}

你没有看错,这两个属性的属性值完全相同,都可以去这几个值:

  • start:对齐单元格的起始边缘。
  • end:对齐单元格的结束边缘。
  • center:单元格内部居中。
  • stretch:拉伸,占满单元格的整个宽度(默认值)。

start:单元格的内容头部对齐:

.container{
display: grid;
width: 200px;
border: 1px dashed red;
grid-template-columns: 100px 100px;
grid-template-rows: 100px 100px;
justify-items: start;
}

效果如图:

end:单元格的内容尾部对齐:

.container{
display: grid;
width: 200px;
border: 1px dashed red;
grid-template-columns: 100px 100px;
grid-template-rows: 100px 100px;
justify-items: end; /* 对齐单元格的结束边缘 */
}

效果如图:

center:单元格内部居中

.container{
display: grid;
width: 200px;
border: 1px dashed red;
grid-template-columns: 100px 100px;
grid-template-rows: 100px 100px;
justify-items: center; /* 单元格内部居中 */
}

效果如图:

stretch:占据单元格整个宽度(拉伸):

.container{
display: grid;
width: 200px;
border: 1px dashed red;
grid-template-columns: 100px 100px;
grid-template-rows: 100px 100px;
justify-items: stretch; /* 默认值-拉伸占据整个宽度 */
}

效果如图:

这里只演示下justify-items 属性,对应单元格的左中右,相信大家也有点感觉了,align-items 取值是一样的,对应的是单元格的上中下部分,这里就不再演示了,感兴趣的小伙伴自行尝试哟

同样,这两个属性也有复合属性place-items

语法:

place-items: <align-items> <justify-items>;

第一个值为单元格内容垂直位置,第二个值为单元格水平位置

.container{
display: grid;
width: 200px;
border: 1px dashed red;
grid-template-columns: 100px 100px;
grid-template-rows: 100px 100px;
place-items: center center; /* 单元格内容水平垂直居中 */
}

效果如图:

注意:如果省略第二个值,则默认与第一个值相等

(6)justify-content 和 align-content

justify-content属性是整个内容区域在容器里面的水平位置(左中右)

align-content属性是整个内容区域的垂直位置(上中下)

注意区分justify-items 和 align-items属性,一个是内容相对于单元格位置,一个是整个内容区域相对于父容器位置!!!

语法:

.container {
justify-content: start | end | center | stretch | space-around | space-between | space-evenly;
align-content: start | end | center | stretch | space-around | space-between | space-evenly;
}

你又没有看错,这两个属性的属性值也是完全相同,都可以去这几个值:

  • start - 对齐容器的起始边框。

  • end - 对齐容器的结束边框。

  • center - 容器内部居中。

  • stretch - 项目大小没有指定时,拉伸占据整个网格容器。

  • space-around - 每个项目两侧的间隔相等。所以,项目之间的间隔比项目与容器边框的间隔大一倍。

  • space-between - 项目与项目的间隔相等,项目与容器边框之间没有间隔。

  • space-evenly - 项目与项目的间隔相等,项目与容器边框之间也是同样长度的间隔。

同样,这里我也只演示justify-content属性,align-content 属性完全一致,只是方向不同,感兴趣的小伙伴自行尝试下啦~~

start:对齐容器的起始边框。

.container{
display: grid;
width: 300px;
border: 1px dashed red;
grid-template-columns: 100px 100px;
grid-template-rows: 100px 100px;
justify-content: start;/* 对齐容器的起始边框(默认) */
}

end:对齐容器的结束边框。

.container{
justify-content: end;/* 对齐容器的结束边框 */
}

center:容器内部居中。

.container{
justify-content: center;/* 容器内部居中 */
}

space-around:每个项目两侧的间隔相等。项目之间的间隔比项目与容器边框的间隔大一倍。

.container{
justify-content: space-around;/* 每个项目两侧的间隔相等。项目之间的间隔比项目与容器边框的间隔大一倍 */
}

space-between:项目与项目的间隔相等,项目与容器边框之间没有间隔。

.container{
justify-content: space-between;/* 项目与项目的间隔相等,项目与容器边框之间没有间隔。 */
}

space-evenly:项目与项目的间隔相等,项目与容器边框之间也是同样长度的间隔。

.container{
justify-content: space-evenly;/* 项目与项目的间隔相等,项目与容器边框之间也是同样长度的间隔。 */
}

相信大家看完这几个属性值后,学过 Flex布局 的小伙伴肯定再熟悉不过了,在flex布局中项目与容器对齐方式也类似这几种

同样滴,这两个属性也是有复合属性的:place-content

语法:

place-content: <align-content> <justify-content>

第一个值整个内容相对容器的垂直位置,第二个值整个内容相对容器的水平位置

.container{
display: grid;
width: 300px;
height: 300px;
border: 1px dashed red;
grid-template-columns: 100px 100px;
grid-template-rows: 100px 100px;
place-content: center center; /* 整体内容水平垂直居中 */
}

效果如图:

注意:如果省略第二个值,则默认与第一个值相等

四、项目属性

注意:项目属性需要定义在项目上才能生效!

(1)grid-column-start、grid-column-end、grid-row-start、grid-row-end

这四个属性是用于指定某个项目的位置,根据项目的四个边框来定位在哪根儿网格线

  • grid-column-start 属性:左边框所在的垂直网格线

  • grid-column-end 属性:右边框所在的垂直网格线

  • grid-row-start 属性:上边框所在的水平网格线

  • grid-row-end 属性:下边框所在的水平网格线

下面所演示的代码片段也是基于前面的例子:

.container{
display: grid;
width: 300px;
height: 300px;
border: 1px dashed red;
grid-template-columns: 100px 100px;
grid-template-rows: 100px 100px;
}
.item-1 {
grid-column-start: 2;/* 开始于第二根网格线 */
grid-column-end: 4;/* 结束于第四根网格线 */
background-color: #aaaaff;
}

效果如图:

只有项目一指定了具体,其他项目自动布局,为了便于观察,再定位一次:

.item-1 {
grid-column-start: 2;/* 垂直第一根 */
grid-column-end: 4; /* 垂直第四根 */
grid-row-start: 1;/* 水平第一根 */
grid-row-end: 3;/* 水平第三根 */
background-color: #aaaaff;
}

效果如下:

这四个属性值还可以使用span关键字,表示“跨越”,就像table表格的单元格合并colspan和rowspan

.item-1 {
grid-column-start: span 2;/* 横跨两个网格线 */
/* 等同于 */
grid-column-end: span 2;/* 横跨两个网格线 */
background-color: #aaaaff;
}

效果如图:

这个结果相信有些小伙伴会说其他子元素为什么没有在第一个子元素之后继续排列?

我想说的是grid-template-columns: 100px 100px; 我只设置了两列,如果改成grid-template-columns: 100px 100px 100px; 这样,那容器剩余的空间就可以补齐啦~

注意:使用这四个属性,如果产生了项目的重叠,则使用z-index属性指定项目的重叠顺序

(2)grid-column 和 grid-row

grid-column:grid-column-startgrid-column-end的合并简写形式

grid-row:grid-row-start属性和grid-row-end的合并简写形式

语法:

.item {
grid-column: <start-line> / <end-line>;
grid-row: <start-line> / <end-line>;
}

来个栗子:

.item-1 {
grid-column: 1 / 3; /* 占据水平方向上的第1根和第3根 */
grid-row: 2 / 4; /* 占据垂直方向上的第2根和第4根 */
background-color: #aaaaff;
}

效果如图:

注意:斜杠以及后面的部分可以省略,默认跨越一个网格

(3)justify-self 和 align-self

justify-self属性设置单元格内容的水平位置(左中右),跟justify-items属性的用法完全一致,但只作用于单个项目。

align-self属性设置单元格内容的垂直位置(上中下),跟align-items属性的用法完全一致,也是只作用于单个项目。

语法:

.item {
justify-self: start | end | center | stretch;
align-self: start | end | center | stretch;
}

取值:

  • start:对齐单元格的起始边缘。

  • end:对齐单元格的结束边缘。

  • center:单元格内部居中。

  • stretch:拉伸,占满单元格的整个宽度(默认值)

.item-1 {
justify-self: start; /* 指定项目单元格左对齐 */
background-color: #aaaaff;
}

这里我就演示一个就行了,其他都一样,有手就行,大家可以自行尝试下

place-self属性是align-self属性和justify-self属性的合并简写形式

语法:

place-self: <align-self> <justify-self>;

例子:

.item-1 {
place-self: center center;
background-color: #aaaaff;
}

你需要的Grid布局入门教程的更多相关文章

  1. CSS Grid布局入门

    相信大家都比较熟悉flex布局了,最近有空研究了波grid布局,感觉虽然兼容性还不是太高,应用不是太普遍,但是功能非常强大.未来应该是grid+flex为主流,grid是二维布局,很灵活,适合整体构架 ...

  2. CSS布局-flex布局入门教程

    前言 2009年,W3C 提出了一种新的方案----Flex 布局,可以简便.完整.响应式地实现各种页面布局.目前,它已经得到了所有浏览器的支持,这意味着,现在就能很安全地使用这项功能. 查询兼容 F ...

  3. Div+CSS布局入门教程

    http://www.blueidea.com/tech/site/2006/3574.asp ———————————————————————————————————————————————————— ...

  4. Swift语言Auto Layout入门教程:上篇

    原文:Beginning Auto Layout Tutorial in Swift: Part 1/2,译者:@TurtleFromMars 开始用自动布局约束的方式思考吧! 更新记录:该教程由Br ...

  5. WPF入门教程系列八——布局之Grid与UniformGrid(三)

    五. Grid Grid顾名思义就是“网格”,它的子控件被放在一个一个实现定义好的小格子里面,整齐配列. Grid和其他各个Panel比较起来,功能最多也最为复杂.要使用Grid,首先要向RowDef ...

  6. 【CSS】343- CSS Grid 网格布局入门

    CSS Grid(网格) 布局使我们能够比以往任何时候都可以更灵活构建和控制自定义网格.Grid(网格) 布局使我们能够将网页分成具有简单属性的行和列. 它还能使我们在不改变任何HTML的情况下,使用 ...

  7. CPF 入门教程 - 控件布局(六)

    CPF netcore跨平台桌面UI框架 系列教程 CPF 入门教程(一) CPF 入门教程 - 数据绑定和命令绑定(二) CPF 入门教程 - 样式和动画(三) CPF 入门教程 - 绘图(四) C ...

  8. SharePoint 2013 入门教程之创建页面布局及页面

    在SharePoint的使用过程中,页面布局和页面时很重要的两个概念,主要用于数据个性化展示,下面,我们简单介绍一下SharePoint的页面布局和页面的个性化. 一. SharePoint页面模型概 ...

  9. 无废话ExtJs 入门教程十六[页面布局:Layout]

    无废话ExtJs 入门教程十六[页面布局:Layout] extjs技术交流,欢迎加群(201926085) 首先解释什么是布局: 来自百度词典的官方解释:◎ 布局 bùjú: [distributi ...

随机推荐

  1. 【LeetCode】503. Next Greater Element II 解题报告(Python & C++)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 暴力解法 单调递减栈 日期 题目地址:https:/ ...

  2. 第三十一个知识点:Game Hopping证明

    第三十一个知识点:Game Hopping证明 关于安全证明, 目前主流的方法有安全归约证明 (由 single game 实现) 和 Game Hopping (由 game sequence 实现 ...

  3. A Simple Framework for Contrastive Learning of Visual Representations

    目录 概 主要内容 流程 projection head g constractive loss augmentation other 代码 Chen T., Kornblith S., Norouz ...

  4. matplotlib 进阶之Tight Layout guide

    目录 简单的例子 Use with GridSpec Legend and Annotations Use with AxesGrid1 Colorbar 函数链接 matplotlib教程学习笔记 ...

  5. Java网络编程Demo,使用TCP 实现简单群聊功能Groupchat,创建一个服务端,使多个客户端都能收到消息

    效果图: 开启服务端 客户端一 客户端二 客户端三 实现代码: 客户端类 import java.io.IOException; import java.net.ServerSocket; impor ...

  6. 编写Java程序,实现从控制台输入对应个数的整数,输出对输入整数的从大到小显示

    编写Java程序,实现从控制台输入对应个数的整数,输出对输入整数的从大到小显示 效果如下: 实现代码: import java.util.Arrays; import java.util.Scanne ...

  7. ssm项目使用过滤器出现4040错误

    目录 问题 解决方法 (1)方法一 (2)方法二 问题 过滤器处理乱码问题 public class CharFilter implements Filter { @Override public v ...

  8. Log4j2完整XML参考(详细注释说明)

    1.说明 本文提供完整的log4j2.xml配置文件, 供开发中参考使用,可以作为模板, 配置对应实现如下常用的功能: 1.自动检测和重新加载配置,每10分钟(600s)检测一次 2.每个日志文件最大 ...

  9. Clover支持目录多标签页

    1.简介 Clover是Windows Explorer资源管理器的一个扩展, 为其增加类似谷歌 Chrome 浏览器的多标签页功能. 2.推荐用法 下面是我使用的Clover的截图: 可以看到同时打 ...

  10. html基础 button按钮标签

    场景:在网页中显示用户点击的按钮标签名:button 注意:form不能少,少了不会出效果 html代码 <form > 昵称: <input type="text&quo ...