css中网格布局的案例分析

  介绍

小编给大家分享一下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

css中网格布局的案例分析