小编给大家分享一下css中网格布局的案例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获、下面让我们一起去了解一下吧!
css网格布局(又称“网格”),是一种二维网格布局系统。css在处理网页布局方面一直做的不是很好。一开始我们用的是表(表)格布的局,然后用浮子(浮动)、位置(定位)和inline-block(行内块)布的局,但是这些方法本质上是黑客,遗漏了很多功能,例如垂直居中。后来出了flexbox盒布的局,解决了很多布局问题,但是它仅仅是一维布的局,而不是复杂的二维布的局,实际上它们(flexbox与网格)能很好的配合使用。
浏览器支持情况
在我们开始正式学习网格布局之前,先看一下我能用上网格布局在各个浏览器下的支持情况是很有用的,
基本概念
要想学网格布好局的用法,基本概念的介绍是少不了的,虽然看起来比较枯燥。
网格容器(网格容器)
通过显示属性设置属性值为网格或inline-grid可以创建一个网格容器。网格容器中的所有子元素就会自动变成网格项目(网格项目)
网格线(网格线)
组成网格线的分界线。它们可以是列网格线(列网格线),也可以是行网格线网格线(行)并且居于行或列的任意一侧
网格轨道(网格跟踪)
两个相邻的网格线之间为网格轨道。你可以认为它们是网格的列或行
网格单元(网格单元)
两个相邻的列网格线和两个相邻的行网格线组成的是网格单元,它是最小的网格单元
网格区(网格,区)
网格区是由任意数量网格单元组成
基本属性及作用
一个简单例子
要介绍网格布局属性,让我们先从一个简单例子开始:
如上图所示,如果我们要实现一个3 x3的正方形矩阵,用网格布局要怎么实现?
& lt; div类=癱ontainer"比; & lt; div> & lt;/div> & lt; div> & lt;/div> & lt; div> & lt;/div> & lt; div> & lt;/div> & lt; div> & lt;/div> & lt; div> & lt;/div> & lt; div> & lt;/div> & lt; div> & lt;/div> & lt; div> & lt;/div> & lt;/div>
。容器{ 显示:网格; 宽度:200 px; 身高:200 px; grid-template-rows:重复(3、50 px); grid-template-columns:重复(3、50 px); grid-row-gap: 10 px; grid-column-gap: 10 px; } .container p { background - color: # ccc; 边界:1 px固体# 333; }
如上面代码所示,3 x3的矩阵布的局,用网格布局去写,非常简单方便,相对于使用其他布局来说,网格布局的优点就显现出来了,那么,接下来就让我们看看电网局部中那些常用属性:
grid-template-rows:指定的每个值可以创建每行的高度。行高的尺寸可以是任何非负值,长度可以是px, %, em等长度单位的值
grid-template-columns:指定的每个值来创建每列的列宽
重复函数:使用重复()可以创建重复的网格轨道。这个适用于创建相等尺寸的网格项目和多个网格项目,重复()接受两个参数:第一个参数定义网格轨道应该重复的次数,第二个参数定义每个轨道的尺寸
grid-column-gap和grid-row-gap属性用来创建列与列,行与行之间的间,距间距(Gap)可以设置任何非负值,长度值可以是px, %, em等单位值。
网格线号码定位
依旧是上面html代码,一个3 x3的矩阵,不同的是这次我们通过网线号码来定位某一个特定方块。
。容器{ 显示:网格; 宽度:200 px; 身高:200 px; grid-template-rows:重复(3、50 px); grid-template-columns:重复(3、50 px); } .container div { background - color: # ccc; 边界:1 px固体# 333; grid-column-start: 2; grid-column-end: 3; grid-row-start: 2; grid-row-end: 3;/*网格:2/2/3/3;*/}
通过上面的代码我们可以实现如下效果:
我们定位矩阵正中间的小方块显示出来,其余的就不显示了、下面我们网格线号码定位的那些属性:
每条线是从网格轨道开始,网格的网格线从1开始,每条网格线逐步增加1
grid-row-start:表示开始的行网格线序号
grid-row-end:表示结束的行网格线序号
grid-column-start:表示开始的列网格线序号
grid-row-end:表示结束的列网格线序号
如果一个网格项目跨度只有一行或一列,那么grid-row-end和grid-column-end不是必需的
栅格:网格区域,也是用来定位,如果只提供一个值,它指定了grid-row-start和grid-column-start的值。如果提供两个值,第一个值是grid-row-start, grid-column-start的值,第二个值是grid-row-end, grid-column-end的值,两者之间必须要用/隔开。如果指定四个值,第一个值对应grid-row-start,第二个值对应grid-column-start,第三个值对应grid-row-end和第四个值对应grid-column-end