博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
进击的布局之Grid Layout
阅读量:6236 次
发布时间:2019-06-22

本文共 3288 字,大约阅读时间需要 10 分钟。

文中所有示例,可以下载,或直接去查看或调试~❤️

简介

布局问题一直在不断地被优化,最初可能是使用block、inline-block、table,或者直接使用float、position等... 后来flex出现了,我们可以快速地用它解决元素的一维分布问题,例如居中,平均分布等,这种处理是针对项目的一条轴线,所以可以称为一维布局

Grid Layout可以看成是flex布局的升级版本,在2013年,《CSS布局的未来趋势》一文中就提出了Grid Layout,在2017年3月份之后,各大主流浏览器相继宣布开始支持css grid属性。
Grid Layout(又名“网格”)是一个二维的基于网格的布局系统,它将容器划分成"行"和"列",产生单元格,然后指定"项目所在"的单元格,所以可以称为二维布局。网格布局的目的只在于完全改变我们设计基于网格的用户界面的方式。

浏览器支持度

具体的属性可到caniuse上查询

基本概念

1.网格容器(Grid Container)

应用 display: grid 的元素。这是所有 网格项(grid item)的直接父级元素。

2.网格项(Grid Item)

网格容器(Grid Container)的子元素.

3.网格线(Grid Line)

构成网格结构的分界线。它们既可以是垂直的(“列网格线(column grid lines)”),也可以是水平的(“行网格线(row grid lines)”),并位于行或列的任一侧。

4.网格轨道(Grid Track)

两条相邻网格线之间的空间。你可以把它们认为网格的列或行。

5.网格单元格(Grid Cell)

行和列的交叉区域,是 Grid(网格) 系统的一个“单元”。

6.网格区域(Grid Area)

4条网格线包围的总空间。一个 网格区域(Grid Area) 可以由任意数量的网格单元格(Grid Cell) 组成,这个取决于开发者的定义

容器属性

grid/inline-grid

display: grid // 常规网格布局display: inline-grid // 行内元素网格布局display: subgrid // 子元素网格布局继承,暂无浏览器支持查询复制代码

grid-template-columns / grid-template-rows

grid-template-columns // 属性定义每一列的列宽grid-template-rows // 属性定义每一行的行高复制代码

示例:

row-gap / column-gap / gap

row-gap: 20px // 行间距column-gap: 20px // 列间距gap: 20px // 简写复制代码

示例:

grid-template-areas

定义容器区域,这个属性单独看没有意义,需要单配项目属性grid-area使用,稍后讲解~

grid-auto-flow

grid-auto-flow: row / column / row dense / column dense// 排列顺序,默认是先行后列,还可以选择先列后行,先行后列尽量不出现空白区域,先列后行尽量不出现空白区域复制代码

示例:

justify-item / align-item / place-item

justify-items // 属性设置单元格内容的水平位置(左中右)align-items // 属性设置单元格内容的垂直位置(上中下)place-items // 简写,如果省略第二个值,则浏览器认为与第一个值相等复制代码
可选值:start:对齐单元格的起始边缘 end:对齐单元格的结束边缘 center:单元格内部居中 stretch:拉伸,占满单元格的整个宽度(默认值)复制代码

justify-items或者align-item填写的时候,另外一个值默认是stretch

示例:

justify-content / align-content / place-content

justify-content // 属性是整个内容区域在容器里面的水平位置(左中右)align-content // 属性是整个内容区域的垂直位置(上中下)。place-content // 简写,第二个值不写,默认读第一个值复制代码
可选值 :startendcenterstretchspace-around // 每个项目两侧的间隔相等。所以,项目之间的间隔比项目与容器边框的间隔大一倍。spance-between // 项目与项目的间隔相等,项目与容器边框之间没有间隔。space-evenly // 项目与项目的间隔相等,项目与容器边框之间也是同样长度的间隔。如果省略第二个值,浏览器就会假定第二个值等于第一个值。复制代码

grid-auto-columns / grid-auto-rows

有时候,一些项目的指定位置,在现有网格的外部。比如网格只有3列,但是某一个项目指定在第5行。这时,浏览器会自动生成多余的网格,以便放置项目。grid-auto-columns属性和grid-auto-rows属性用来设置,浏览器自动创建的多余网格的列宽和行高。它们的写法与grid-template-columns和grid-template-rows完全相同。如果不指定这两个属性,浏览器完全根据单元格内容的大小渲染,我们在这个示例中提到过 ps: 列的话不要尝试,以为列增加不是单个而是一整列,是算到网格里的

grid-template / grid

grid-template属性是grid-template-columns、grid-template-rowsgrid-template-areas这三个属性的合并简写形式。 grid属性是grid-template-rows、grid-template-columns、grid-template-areas、 grid-auto-rows、grid-auto-columns、grid-auto-flow这六个属性的合并简写形式。 写起来比较魔性,不介意大家平时书写,具体可以去详细解读一下

项目属性

grid-column-start / grid-column-end / grid-row-start / grid-row-start

grid-column-start: 1;grid-column-end: 3;grid-row-start: 2;grid-row-start: 3;复制代码

示例:

grid-column / grid-row

grid-column: 
// 简写grid-row:
// 简写复制代码

示例:

grid-area

// 指定项目放在哪一个区域。grid-area: row-start / column-start / row-end / column-end / 区域名复制代码

起始网格线可以通过命名使用

示例:

justify-self / align-self / place-self

justify-self // 属性设置单元格内容的水平位置(左中右),跟justify-items属性的用法完全一致,但只作用于单个项目align-self // 属性设置单元格内容的垂直位置(上中下),跟align-items属性的用法完全一致,也是只作用于单个项目place-self // 简写复制代码

示例:

总结

Grid Layout 布局虽然属性较多,但是通过对行列的自由控制,极大地简化了布局的开发,大家抓紧尝试起来!❤

转载于:https://juejin.im/post/5c9c8ceaf265da611b1ee541

你可能感兴趣的文章
PlayScala 2.5.x - 关于Content-Type的注意事项
查看>>
linux配置了java环境变量仍然报java: command not found
查看>>
Windows8.1
查看>>
maven编译的时候跳过test
查看>>
java回调函数的理解
查看>>
centos7的使用
查看>>
【持续更新】IDEA常用快捷键
查看>>
CentOS 编译安装新版git
查看>>
12.6 Nginx安装 12.7 默认虚拟主机 12.8 Nginx用户认证12.9 Nginx域名重定向
查看>>
tomcat 启动和关闭源码查看
查看>>
JavaScript设计模式之观察者模式
查看>>
osx中让idea使用官方版的git
查看>>
js 数组 map方法
查看>>
Linux 工程师技术
查看>>
Apk代码混淆
查看>>
线程池监控
查看>>
php源码编译常见错误解决方案
查看>>
ios 开发中UISegmentedControl 用法
查看>>
分布式网站架构后续:zookeeper技术浅析
查看>>
Redis学习(二)—— 数据类型(1)
查看>>