CSS Grid布局这样玩
zgho4427
8年前
<p>自从去年年半年开始,CSS Grid布局的相关教程在互联网上就铺天盖地,可谓是声势浩大。就针对于Web布局而言,个人认为Grid布局将是Web布局的神器,它改变了以往任何一种布局方式或者方法。不管以前的采用什么布局方法都可以说是一维的布局方式,而Grid最大的特色,采用了二维布局。@Rachel Andrew也一直致力于完善Grid的规范。</p> <p>就我个人而言,我也一直在不断的关注这个布局利器的相关更新,自从最初规范的出来,到目前规范的完善。在站上也不断的在更新CSS Grid布局的使用。虽然这方向的教程已经很多了,但各有千秋,我追求以最简单,最直接的方式来阐述它的使用方式方法。让初学者能尽快的掌握其使用规则。</p> <p>前段时间@Mirza Joldic在Medium上发布了 一篇文章 ,通过几个Gif动态非常形象的阐述了CSS Grid的几个核心概念以及使用方法,今天我就借花献佛,用这几张图让初学者快速掌握CSS Grid的核心概念和使用技巧。</p> <h2>Web布局的历史演变</h2> <p>自从Web出来至今,Web的布局也经过了几个演变,下图可以一目了然:</p> <p style="text-align:center"><img src="https://simg.open-open.com/show/beff4e276f0342a41dfc88425aaea6ba.png"></p> <p>有关于Web布局的演变史,去年也整理过一篇相关的文章简单的阐述了这方面的故事,如果你感兴趣的话,可以点击这里进行了解。在Web的学习过程中,学习Web布局是一个不可避免的过程,而随着前端技术的日新月异的变化,布局方式也在不断的更新,早在2013年@Peter Gasston就对CSS布局的未来趋势就做过预判断,文章中就提供了CSS Grid的布局。如果今天来看,这种趋势的预判是正确的,特别是今年3月份之后,各大主流浏览器都发布了对CSS Grid的支持。既然如此,学习CSS Grid相关的知识就很有必要。</p> <p>既然掌握CSS Grid很有必要,那用什么样的方式能最快的掌握CSS Grid相关的知识呢?这很重要。 特别是@Mirza Joldic在Medium上发布的文章,里面的动图让我耳目一新,通过简单的几张图,就把CSS Grid的几个核心介绍的非常清楚,我觉得很有必要拿出来与大家分享。</p> <p>在继续下面的内容之前,再次感谢@Mirza Joldic的付出。那咱们就不说废话了,开始今天的学习之旅。</p> <h2>CSS Grid布局的介绍</h2> <p>学习CSS Grid布局更多的相关知识,我觉得通过一些工具会对大家的理解更有帮助,到目前为止,这方面的在线工具已经有很多种,比如:</p> <ul> <li><a href="/misc/goto?guid=4959747922682840156" rel="nofollow,noindex">GRID GARDEN</a> :通过一个小游戏的方式,让你快速掌握CSS Grid的相关知识,这个有点类似于 FLEXBOX FROGGY</li> <li><a href="/misc/goto?guid=4959747922769332011" rel="nofollow,noindex">Griddy</a> by @drewisthe</li> <li><a href="/misc/goto?guid=4959747922858404105" rel="nofollow,noindex">CSS Grid Cheat Sheet</a> by @alialaa</li> </ul> <p>下面的动图是使用@Mirza Joldic写的 CSS Grid Playground 小工具。动图来了:</p> <p style="text-align:center"><img src="https://simg.open-open.com/show/34f6d1776e403eb6480a989267fa8f70.gif"></p> <p>这里要提两个核心概念,这两个核心概念有点类似于Flexbox布局:</p> <ul> <li>Grid容器(对应Flexbox布局中的Flex容器)</li> <li>Grid项目(对应Flexbox布局中的Flex项目)</li> </ul> <p>比如一个这样的HTML结构:</p> <p style="text-align:center"><img src="https://simg.open-open.com/show/d8c57c4a591be6e56f213ce5dfba1784.png"></p> <p>使用 CSS Grid布局首要的第一步,就是通过 display:grid; 来对容器声明一个网格容器,那么这个 div 元素里面对应的子元素就自动成为网格项目。</p> <p style="text-align:center"><img src="https://simg.open-open.com/show/1993a12eabd8a085d037867e8ac5059d.gif"></p> <p>虽然你在 div.grid-container 中设置了 display:grid; ,声明了这个元素为Grid容器,但在浏览器中,并看不到有任何的变化。但在在幕后中,他们还是发生了变化, div.grid-container 是一个Grid容器,他的所有子元素就自动变成了网格项目。</p> <p>接下来,使用 grid-template-columns: 1fr 1fr 1fr; 来定义三列网格:</p> <p style="text-align:center"><img src="https://simg.open-open.com/show/153af1e4863b3b720e1c1c8746e7c666.gif"></p> <p>从gif图中就明显的看出来,现在有点变化了,颜色块变小了,但很难区分出有何变化,为了让效果之间有更突出的差异,再给 .grid-container 中添加 grid-gap:5px :</p> <p style="text-align:center"><img src="https://simg.open-open.com/show/83b3f8838b0e758d40c872fbc28972ae.gif"></p> <p>看到变化了吧,整个网格分了三个列,单元格之间有 5px 的间距,同时每列的列宽是整个宽度的三分之一,那是因为我们采用了 fr 单位,而且把整个网格分成了三列,每列的宽度是 1fr 。这里告诉我们三个知识点:</p> <ul> <li>grid-template-columns 用来把网格指定列的宽度</li> <li>grid-gap 用来指定列(或行)的间距</li> <li>fr 可以自动根据网格容器的宽度来计算列的宽度</li> </ul> <p>现在我们把 grid-template-columns 的值改成: 1fr 2fr 1fr ,对应的效果就会变成:</p> <p style="text-align:center"><img src="https://simg.open-open.com/show/f2bbfb09571cc353d38d166b8d7fab4d.gif"></p> <p>现在第二列的宽度是第一列和最后一列的两倍。这也再次证明 fr 单位的强大之处,使用它可以让你很容易定义你的网格尺寸。</p> <p>现在越来越接近我们想要的网格。但需求是不断变化的,比如我们现在想让顶部的第一行尽可能的宽,比如说跨整个网格列(比如我们网页的头部,或者说我们常见的导航)。如此一来,只需要在第一个网格上使用 grid-column: 1 / 4 :</p> <p style="text-align:center"><img src="https://simg.open-open.com/show/18988a510004e6d28e22921537a084a5.gif"></p> <p>或许第一次接触 1 / 4 会令你感到神秘,其实这个涉及到了CSS Grid中的重要概念之一,那就是网格线,其中第一个数字是列的起始网格线位置,第二个数字是线束网格线的位置。对于一个CSS Grid,可以通过 grid-template-columns 创建列网格线, grid-template-rows 创建行网格线。这种方式创建的是一种显式的网格线。当然,除了这种方式,还可以创建隐式网格线。除此之外,还可以使用 grid-auto-rows 和 grid-auto-columns 可以创建一个隐式网格。这个隐式网格对应的网格线就被称之为隐式网格线。下图简单的展示了示例中的网格线示意图:</p> <p style="text-align:center"><img src="https://simg.open-open.com/show/f44d8635575ec70488dffb564bc8a998.png"></p> <p>接下来,我们想要有一个 300px 的侧边栏高度,并且让他的位置是垂直方向的 2 / 3 。我们可以使用 grid-row: 2 / 4 来实现,这个特性和 grid-column 非常的类似。这个时候,效果变成这样:</p> <p style="text-align:center"><img src="https://simg.open-open.com/show/534982ed77164d8e864d81740bab4a85.gif"></p> <p>其实CSS Grid看上去和表格非常的类似,在表格中我们有一个专业的术语,合并单元格。其实在CSS Grid布局中,我们同样有一个类似的特性,那就是在 grid-column 或者 grid-row 中引入关键词 span ,在关键词 span 后面紧跟一个数值,就是表示合并单元格的数量,先来看下图:</p> <p style="text-align:center"><img src="https://simg.open-open.com/show/d88eaa19465e19408f23598287becf0a.gif"></p> <p>上面的示例中,我们使用到了 grid-column: 2 / span 1 和 grid-row: 2 / span 2 。其中 grid-column: 2 / span 1 表示从列网格线 2 开始,跨度是 1 个列网格线(其实就是合并一个列单元格)。而 grid-row: 2 / span 2 表示的是从行网格线 2 开始,跨度是两个两个线(其实就是合并两个行单元格)。</p> <p>接着我们来做页脚,在做页脚之前,我们先删除两个网格项目,因为不需要他们了。做页脚和做页头非常的类似,继续使用 grid-column: 1 / 4 即可:</p> <p style="text-align:center"><img src="https://simg.open-open.com/show/849df6873541d81ad630079c00486d77.gif"></p> <p>通过上面的方式,我们可以轻易的控制网格,也能非常容易的实现一个Web面页的布局,比如一个三列的布局。但我们在布局中经常还需要控制对齐方式,特别是在CSS Grid的布局当中,比如下面的示例中,我们第三列并未占满整个高度,这个时候希望它能底部对齐。此时为了实现这样的效果,需要使用到CSS中的对齐模块特性,比如在这里,我们可以使用 align-self: end 来实现:</p> <p style="text-align:center"><img src="https://simg.open-open.com/show/cac6cfc6fd58195f5f496fdc92b1a47c.gif"></p> <p>align-self 是CSS中的一个新模块特性 <strong> Box Alignment </strong> 中的一个属性。有关于这个模块的的功能还是非常的实用。@Rachel Andrew整理了一份 Box Alignment Cheatsheet ,里面详细介绍了Box Alignment的使用。简单的来讲,这个规范中有三个关键部分:</p> <ul> <li><a href="/misc/goto?guid=4959747922936233924" rel="nofollow,noindex">Positional Alignment</a> :关键词有 start 、 end 、 center</li> <li><a href="/misc/goto?guid=4959747923026884189" rel="nofollow,noindex">Baseline Alignment</a> :关键词有 baseline 、 first baseline 、 last baseline</li> <li><a href="/misc/goto?guid=4959747923102573780" rel="nofollow,noindex">Distributed Alignment</a> :关键词有 space-between 和 space-around</li> </ul> <p>其实你要是对Flexbox熟悉的话,你或许感觉这个Box Alignment有点类似于Flexbox中的一些控制Flex项目对齐方式的属性。事实是这样的,如果你感兴趣想深入的了解这方面的相关知识,建议你花点时间阅读《 Web布局新系统:CSS Grid,Flexbox和Box Alignment 》一文。</p> <p>如果你对上面的相关知识有所了解的话,你就可以很轻易的使用CSS Grid相关知识实现一个常用的Web页面布局效果。比如下面这张图,为了好完,我把主内容的容器设置了具体的宽度,并且通过Box Alignment属性,让这个区域水平垂直居中:</p> <p style="text-align:center"><img src="https://simg.open-open.com/show/48de0c3a8f0d1b92796ab5ec56be3397.gif"></p> <p>整个题外话,虽然实现 水平垂直居中的解决方案 已有很多种了,但Box Alignment模块将是最佳方式。</p> <p>如果你感兴趣的话,你也可以通过@Mirza Joldic写的 CSS Grid Playground 小工具去尝试各式各样的网格布局效果。从而加强对CSS Grid的概念。当然,在使用它去做一些事情或者做一些创意之前,还是很有必要对CSS Grid基础要有一个简单的了解。个人建议你花点时间阅读一下下面几篇文章:</p> <ul> <li><a href="/misc/goto?guid=4959747923191831171" rel="nofollow,noindex">CSS Grid布局:图解网格布局中术语之一</a></li> <li><a href="/misc/goto?guid=4959747923277914579" rel="nofollow,noindex">CSS Grid布局:图解网格布局中术语二</a></li> <li><a href="/misc/goto?guid=4959747923361880124" rel="nofollow,noindex">CSS Grid布局:图解网格布局中术语三</a></li> <li><a href="/misc/goto?guid=4959747923448703004" rel="nofollow,noindex">CSS Grid布局指南</a></li> </ul> <p>当然,如果你深入的学习CSS Grid的相关知识,个人强列你仔细阅读完这里的所有文章。其实我个人也是CSS Grid的极度爱好者,我将在这里不断的更新和发布有关于CSS Grid的相关文章。希望这些文章对你学习和使用CSS Grid有所帮助。</p> <h2>总结</h2> <p>这篇文章借助于@Mirza Joldic写的 CSS Grid Playground 小工具以及 博文 中提供的动图,快速帮助大家理解CSS Grid的核心概念,以及快速使用这些知识掌握CSS Grid相关知识,从而通过掌握的CSS Grid知识创建自己想要的Web布局效果。虽然CSS Grid已经很强大了,但为了能更好的满足Web开发者的需求,它还在不断的更新,不断的提供和完善新特性,有关于这方面的变更,大家可以关注W3C规范的相关更新。当然也可以关注小站有关于CSS Grid相关更新。如果您有这方面的经验,欢迎在下面的评论中与我们一起分享。</p> <p> </p> <h3> </h3> <p>来自:http://www.w3cplus.com/css3/playing-with-css-grid-layout.html</p> <p> </p>