使用CSS Grid布局实现网格的流动


Posted in HTML / CSS onDecember 30, 2014

HTML文档中有文档流,其实在CSS Grid Layout中有网格流。简单点理解就是,在一个被显式声明为网格的容器中,其所有子元素自动被认定为网格单元格,而这些网格单元格在没有被显式设置明确位置时,浏览器将会自动为这些网格单元格的位置进行计算,按照先后顺序从左向右,或从上到下排列。在这里把这种方式称之为网格的流动。

在具体介绍网格流动相关内容之前,我们先一起来回忆一个简单的效果。平时在Web页面制作当中,经常会碰到产品列表展示页面,或者说相册展示页面的效果。如下图所示:

使用CSS Grid布局实现网格的流动

实现上图的效果,大家平时大多会采用floatdisplay:inline-block等方法实现。但这些方法或多或少存在一定的局限性。那么在CSS Grid Layout中,实现这样的布局相对而言会简单多。比如通过网格线,或者网格区域来明确指定各自的位置。不过这样一来,就存在一个潜在的问题:如果在不同的设备上浏览,每行展示的数量不一致时,需要在媒体查询中为每个网格重新指定位置,这变得更为复杂。也不是我们希望的效果。其实在网格布局中还有一种更方便的方法,就是采用网格流来实现。这也是我们今天要说的内容 。

网格的自动流

在CSS Grid Layout中,给元素显式的声明网格,如果没有显式的通过网格线或者网格区域明确指定网格的位置,那么浏览器将会对容器内子元素(网格单元格)进行自动布局。

来看一个简单的示例,假设容器.wrapper中有14个.box(A~O)。容器.wrapper显示的声明为网格,并且不对任何.box做显式的位置定位,这个时候浏览器会自动为.box进行自动布局。为了更好的看到效果,在这个示例中给偶数的.box设置了一个green背景色:

HTML

复制代码
代码如下:

<div class="wrapper">
<div class="box a">A</div>
<div class="box b">B</div>
<div class="box c">C</div>
<div class="box d">D</div>
<div class="box e">E</div>
<div class="box f">F</div>
<div class="box h">H</div>
<div class="box i">I</div>
<div class="box j">J</div>
<div class="box k">K</div>
<div class="box l">L</div>
<div class="box m">M</div>
<div class="box n">N</div>
<div class="box o">O</div>
</div>

CSS

复制代码
代码如下:

.box {
background: orange;
height: 100px;
line-height: 100px;
text-align: center;
color: #fff;
font-size: 3em;
}
.box:nth-child(even){
background: green;
}
.wrapper {
width: 500px;
border: 1px solid orange;
padding: 15px;
margin: 20px auto;</p> <p> display: grid;
grid-template-columns: repeat(5, 100px);
grid-template-rows: auto ;
}

效果如下:

使用CSS Grid布局实现网格的流动

在线案例

不过离文章所示效果还是略有差距,每个.box之间没有间距,我尝试着给.box设置margin值:

使用CSS Grid布局实现网格的流动

在线案例

从效果图中可以明显看出,盒模型解析已做出变化:

使用CSS Grid布局实现网格的流动

上图中可以得知,在CSS Grid Layout中盒模型大小计算变成:容器width = margin-left + margin-right + padding-left + padding-right + content width + border-left-width + border-right+width。比如我们这个示例中,.box设置width:100px,并且有一个margin-right:15px;那实际上.box的内容宽度仅只有85px。这样一来与文章开头示例相左,如果需要做到一致效果,还需对其做一定的变化。这个变化就是对容器.wrapper的宽度和grid-template-columns属性值:


复制代码
代码如下:
<font face="Courier New">
<font face="Courier New">.wrapper {
width: 560px;
border: 1px solid orange;
padding: 15px;
margin: 20px auto;
display: grid;
grid-template-columns: repeat(5, 115px);
grid-template-rows: auto ;
}</font>
</font>

效果如下:

使用CSS Grid布局实现网格的流动

在线案例

或许你会感觉这并没有强大到哪呀,跟以前使用float有太多的变化吗?如果你觉得没有,那请继续往下阅读。

网格流动——列

网格的自动流,在默认情况下都是以行来给元素布局,也就是说grid-auto-flow取值为row。让网格单元格沿着行布局,直到没有可放区域(列的方向),网格单元格会自动换行到下一行排列。哪怕没有显式的声明网格,浏览器也会为创建隐式网格的轨道,用来放自网格单元格。

在实际使用中,可以使用grid-auto-flow属性来做修改,只需要把其默认值row设置成column。网格中的单元将会按列显示,如果需要,还会自动添加列。

一起来看一个示例,你将更易理解:


复制代码
代码如下:

.wrapper {
width: 560px;
border: 1px solid orange;
padding: 15px;
margin: 20px auto;
display: grid;
grid-template-columns: repeat(6, 115px);
grid-template-rows: 115px 115px 115px;
grid-auto-flow: column;
}

效果如下:

使用CSS Grid布局实现网格的流动

在线案例

网格流与定位元素

前两介绍的都是网格容器所有子元素都是按照网格自动流排列。从上面简单的示例中可以得知,只要是网格容器中的子元素,通过grid-auto-flow都可以让其在网格容器中按列,或按行自动排列。可往往有些时候,有些网格需要做一些特殊定位处理。如果其中某个或某几个网格做了特殊处理,那么其他网格还会自动排列?我们将带着这个问题来一起看一个简单的示例:


复制代码
代码如下:
<code>.wrapper { width: 560px; border: 1px solid orange; padding: 15px; margin: 20px auto; display: grid; grid-template-columns: repeat(5, 115px); grid-template-rows: auto ;}.b { grid-column: 3 / 6; grid-row: 2 / 3; outline: 2px solid red;}.f { grid-area: 3 / 1 / 4 / 6; background-color: #f36; outline: 2px solid red;}</code>

效果如下:

使用CSS Grid布局实现网格的流动

在线案例

在这个示例中,盒子.b,通过网格线,将B重新定位新位置上,但这样并没有影响网格的自动流。.b所在的默认位置将由其后面的.c元素补上。同样的,.f元素重新定位后,别的元素补上。而且.f扩展占有多个网格单元格,那么其他的单元格就会自动往后移。如上图所示。

总结

文章中通过简单示例向大家演示了CSS Grid Layout中网格单元格自动排列的实现方法,以及如何通过grid-auto-flow来显式设置自动排列的方向。最后用一个示例向大家展示了,自动排列的网格中,其中某个或某向个网格单元格显式定位后,是否会对网格自动流造成一定的影响。不过如果你看到最后一个示例时,你将不会再质问这个问题。因为效果告诉你一切。

另外网格自动流配合margin和媒体查询将能更好实现Web中相册相关布局,产品展示相关布局。当然你也还可以在这个基础上扩展出更有意义的布局效果。

HTML / CSS 相关文章推荐
CSS3字体效果的设置方法小结
Jun 13 HTML / CSS
纯css3实现的竖形无限级导航
Dec 10 HTML / CSS
前端隐藏出边界内容的实现方法
Apr 14 HTML / CSS
css3动画鼠标放上图片逐渐变大鼠标离开图片逐渐缩小效果
Jan 27 HTML / CSS
Html5 实现微信分享及自定义内容的流程
Aug 20 HTML / CSS
html5 Canvas画图教程(4)—未闭合的路径及渐变色的填充方法
Jan 09 HTML / CSS
JavaScript+Canvas实现自定义画板的示例代码
May 13 HTML / CSS
详解如何在登录过期后跳出Ifram框架
Sep 10 HTML / CSS
ivx平台开发之不用代码实现一个九宫格抽奖功能
Jan 27 HTML / CSS
老生常谈 使用 CSS 实现三角形的技巧(多种方法)
Apr 13 HTML / CSS
POST提交数据常见的四种方式
Jan 18 HTML / CSS
CSS的calc函数用法小结
Jun 25 HTML / CSS
纯css3制作网站后台管理面板
Dec 30 #HTML / CSS
一款纯css3实现的鼠标悬停动画按钮
Dec 29 #HTML / CSS
一款纯css3制作的2015年元旦雪人动画特效教程
Dec 29 #HTML / CSS
一款利用css3的鼠标经过动画显示详情特效的实例教程
Dec 29 #HTML / CSS
纯css3实现照片墙效果
Dec 26 #HTML / CSS
纯css3实现走马灯效果
Dec 26 #HTML / CSS
纯CSS3实现的阴影效果
Dec 24 #HTML / CSS
You might like
PHP 5.0对象模型深度探索之类的静态成员
2008/03/27 PHP
php数组对百万数据进行排除重复数据的实现代码
2010/06/08 PHP
php在线代理转向代码
2012/05/05 PHP
PHP解密Unicode及Escape加密字符串
2015/05/17 PHP
PHP简单实现断点续传下载的方法
2015/09/25 PHP
PHP框架自动加载类文件原理详解
2017/06/06 PHP
jQuery.Validate验证库的使用介绍
2013/04/26 Javascript
javascript 获取函数形参个数
2014/07/31 Javascript
Ext4.2的Ext.grid.plugin.RowExpander无法触发事件解决办法
2014/08/15 Javascript
JS实现网页上随机产生超链接地址的方法
2015/11/09 Javascript
jQuery操作基本控件方法实例分析
2015/12/31 Javascript
JavaScript重载函数实例剖析
2016/05/13 Javascript
AngularJS使用自定义指令替代ng-repeat的方法
2016/09/17 Javascript
微信小程序 空白页重定向解决办法
2017/06/27 Javascript
vue组件实现文字居中对齐的方法
2017/08/23 Javascript
element-ui如何防止重复提交的方法步骤
2019/12/09 Javascript
JS document form表单元素操作完整示例
2020/01/13 Javascript
基于javascript实现碰撞检测
2020/03/12 Javascript
微信小程序之导航滑块视图容器功能的实现代码(简单两步)
2020/06/19 Javascript
CentOS 8.2服务器上安装最新版Node.js的方法
2020/12/16 Javascript
pycharm+PyQt5+python最新开发环境配置(踩坑)
2019/02/11 Python
基于django channel实现websocket的聊天室的方法示例
2019/04/11 Python
python内存动态分配过程详解
2019/07/15 Python
Python统计分析模块statistics用法示例
2019/09/06 Python
使用 Python ssh 远程登陆服务器的最佳方案
2020/03/06 Python
python 判断一组数据是否符合正态分布
2020/09/23 Python
Python常用断言函数实例汇总
2020/11/30 Python
HTML5中通过li-canvas轻松实现单图、多图、圆角图绘制,单行文字、多行文字等
2018/11/30 HTML / CSS
html5 学习简单的拾色器
2010/09/03 HTML / CSS
印度排名第一的蛋糕、鲜花和礼品送货:Winni
2019/08/02 全球购物
网络营销策划方案
2014/06/04 职场文书
高职教师先进事迹材料
2014/08/24 职场文书
六一文艺汇演主持词
2015/06/30 职场文书
2016教师节问候语
2015/11/10 职场文书
mysql 带多个条件的查询方式
2021/06/05 MySQL
10大幻兽系恶魔果实 蝙蝠果实上榜,第一自愈能力强
2022/03/18 日漫