grid布局(css grid布局)

grid布局(css grid布局)p id main toc strong 目录 strong p Grid 布局是什么 Grid 布局和 flex 布局 Grid 的一些基础概念 容器属性介绍 display 属性 grid template columns 属性和 grid template rows 属性

大家好,我是讯享网,很高兴认识大家。



 <p id="main-toc"><strong>目录</strong></p> 

讯享网

Grid 布局是什么?

Grid 布局和 flex 布局

Grid 的一些基础概念

容器属性介绍

display 属性

grid-template-columns 属性和 grid-template-rows 属性

grid-row-gap 属性、grid-column-gap 属性以及 grid-gap 属性

grid-template-areas 属性

grid-auto-flow 属性

justify-items 属性、align-items 属性以及 place-items 属性

stify-content 属性、align-content 属性以及 place-content 属性

grid-auto-columns 属性和 grid-auto-rows 属性

项目属性介绍

grid-column-start 属性、grid-column-end 属性、grid-row-start 属性以及grid-row-end 属性

grid-area 属性

justify-self 属性、align-self 属性以及 place-self 属性

Grid 实战——实现响应式布局

fr 实现等分响应式

repeat + auto-fit——固定列宽,改变列数量

repeat+auto-fit+minmax 去掉右侧空白

repeat+auto-fit+minmax-span-dense 解决空缺问题

Grid 布局兼容性


 布局即网格布局,是一种新的  布局模型,比较擅长将一个页面划分为几个主要区域,以及定义这些区域的大小、位置、层次等关系。号称是最强大的的  布局方案,是目前唯一一种  二维布局。利用  布局,我们可以轻松实现类似下图布局,演示地址

讲到布局,我们就会想到  布局,甚至有人认为竟然有  布局了,似乎没有必要去了解  布局。但  布局和  布局有实质的区别,那就是  布局是一维布局, 布局是二维布局。 布局一次只能处理一个维度上的元素布局,一行或者一列。 布局是将容器划分成了“行”和“列”,产生了一个个的网格,我们可以将网格元素放在与这些行和列相关的位置上,从而达到我们布局的目的。

 布局远比  布局强大!

flex布局示例:

Grid 布局示例:


在网页布局中,一维布局和二维布局是两种常见的布局方式,它们在CSS中通常通过Flexbox(弹性盒子布局)和Grid(网格布局)来实现。

一维布局(Flexbox) vs  二维布局(Grid)

Flexbox是一种一维布局方式,它主要用于处理沿一个方向(水平或垂直)的布局问题。Flexbox可以很容易地对齐和分配容器内项目的空间。

Flexbox的特点:

  1. 单轴布局:Flexbox只在一个方向上进行布局,可以是水平方向(主轴)或垂直方向。
  2. 灵活的空间分配:Flexbox可以根据项目的flex属性自动调整项目的大小,以填充可用空间。
  3. 对齐和排序:Flexbox提供了丰富的对齐和排序选项,可以轻松地对齐项目,以及在主轴和交叉轴上进行排序。

Grid是一种二维布局方式,它允许你同时在水平和垂直方向上进行布局,从而创建复杂的页面布局。

Grid的特点:

  1. 双轴布局:Grid可以在两个方向上进行布局,即行和列。
  2. 模板定义:Grid允许你通过定义行和列的模板来创建复杂的布局结构。
  3. 空间管理:Grid提供了更高级的空间管理功能,如网格线、网格区域和网格间隙。
  4. 对齐和分布:Grid支持在两个轴上对齐和分布项目,提供了更多的对齐和分布选项。

Flexbox和Grid的比较

  • 适用场景:Flexbox适合简单的一维布局,如导航栏、卡片列表等。Grid适合复杂的二维布局,如复杂的网页布局、杂志布局等。
  • 复杂性:Flexbox相对简单,易于理解和使用。Grid功能更强大,但学习曲线可能更陡峭。
  • 兼容性:Flexbox的浏览器兼容性较好,几乎所有现代浏览器都支持。Grid的兼容性也在不断提高,但可能在一些旧版浏览器中存在问题。

我们使用 Grid 实现一个小例子,演示 Grid 的一些基础概念,演示地址

讯享网

容器和项目:我们通过在元素上声明  或  来创建一个网格容器。一旦我们这样做,这个元素的所有直系子元素将成为网格项目。比如上面  所在的元素为一个网格容器,其直系子元素将成为网格项目。

网格轨道: 和  属性来定义网格中的行和列。容器内部的水平区域称为行,垂直区域称为列。上图中 、、 组成了一行,、 则是一列

网格单元:一个网格单元是在一个网格元素中最小的单位, 从概念上来讲其实它和表格的一个单元格很像。上图中 、、、...都是一个个的网格单元

网格线:划分网格的线,称为"网格线"。应该注意的是,当我们定义网格时,我们定义的是网格轨道,而不是网格线。Grid 会为我们创建编号的网格线来让我们来定位每一个网格元素。m 列有 m + 1 根垂直的网格线,n 行有 n + 1 跟水平网格线。比如上图示例中就有 4 根垂直网格线。一般而言,是从左到右,从上到下,1,2,3 进行编号排序。当然也可以从右到左,从下到上,按照 -1,-2,-3...顺序进行编号排序

 布局相关的属性以及值众多,需要记忆的不少,建议可以跟  一起结合起来,边敲代码边理解,再利用一些空闲时间记忆一下。笔者会在介绍每个属性的时候,做个小  演示,建议大家可以自己修改看看效果加深记忆

 布局属性可以分为两大类,一类是容器属性,一类是项目属性。我们先来看容器属性

display 属性

display 属性演示

我们通过在元素上声明  或  来创建一个网格容器。声明  则该容器是一个块级元素,设置成  则容器元素为行内元素

 
     

 

讯享网

 

grid-template-columns 属性和 grid-template-rows 属性

grid-template-columns 和 grid-template-rows 属性演示地址

 属性设置列宽, 属性设置行高,这两个属性在  布局中尤为重要,它们的值是有多种多样的,而且它们的设置是比较相似的,下面针对  属性进行讲解

固定的列宽和行高

 
     

以上表示固定列宽为 200px 100px 200px,行高为 50px 50px

repeat() 函数:可以简化重复的值。该函数接受两个参数,第一个参数是重复的次数,第二个参数是所要重复的值。比如上面行高都是一样的,我们可以这么去实现,实际效果是一模一样的

讯享网

auto-fill 关键字:表示自动填充,让一行(或者一列)中尽可能的容纳更多的单元格。 表示列宽是 200 px,但列的数量是不固定的,只要浏览器能够容纳得下,就可以放置元素,代码以及效果如下图所示:


讯享网

 

fr 关键字: 布局还引入了一个另外的长度单位来帮助我们创建灵活的网格轨道。 单位代表网格容器中可用空间的一等份。 表示第一个列宽设置为 200px,后面剩余的宽度分为两部分,宽度分别为剩余宽度的 1/3 和 2/3。代码以及效果如下图所示:

 
     

minmax() 函数:我们有时候想给网格元素一个最小和最大的尺寸, 函数产生一个长度范围,表示长度就在这个范围之中都可以应用到网格项目中。它接受两个参数,分别为最小值和最大值。 的意思是,第三个列宽最少也是要 300px,但是最大不能大于第一第二列宽的两倍。代码以及效果如下:

讯享网

auto 关键字:由浏览器决定长度。通过  关键字,我们可以轻易实现三列或者两列布局。 表示第一第三列为 100px,中间由浏览器决定长度,代码以及效果如下:

 
     

 

grid-row-gap 属性、grid-column-gap 属性以及 grid-gap 属性

grid-row-gap 属性、grid-column-gap 属性以及 grid-gap 属性演示地址

 属性、 属性分别设置行间距和列间距。 属性是两者的简写形式。

 表示行间距是 10px, 表示列间距是 20px。 实现的效果是一样的

讯享网

以上两种写法效果是一样的。

grid-template-areas 属性

grid-area 以及 grid-template-areas演示地址

 属性用于定义区域,一个区域由一个或者多个单元格组成

一般这个属性跟网格元素的  一起使用,我们在这里一起介绍。  属性指定项目放在哪一个区域

 
     

上面代码表示划分出 6 个单元格,其中值得注意的是  符号代表空的单元格,也就是没有用到该单元格。

html

讯享网

css 

 
     

以上代码表示将类   所在的元素放在上面  中定义的    区域中

grid-auto-flow 属性

grid-auto-flow 属性演示地址

 属性控制着自动布局算法怎样运作,精确指定在网格中被自动布局的元素怎样排列。默认的放置顺序是“先行后列”,即先填满第一行,再开始放入第二行,即下图英文数字的顺序 ,,…。这个顺序由  属性决定,默认值是 。

讯享网

细心的同学可能发现了一个问题,就是第五个项目和第六个项目之间有个空白(如下图所示),这个是由于第六块的长度大于了空白处的长度,被挤到了下一行导致的。在实际应用中,我们可能想让下面长度合适的填满这个空白,这个时候可以设置 ,表示尽可能填满表格。代码以及效果如下所示:

 
     

可以设置 ,表示先列后行,代码以及效果如下图所示:

讯享网

 

justify-items 属性、align-items 属性以及 place-items 属性

justify-items 属性、align-items 属性演示地址

 属性设置单元格内容的水平位置(左中右), 属性设置单元格的垂直位置(上中下)

下面以 justify-items 属性为例进行讲解,align-items 属性同理,只是方向为垂直方向。它们都有如下属性:

 
     

其代码实现以及效果如下:

讯享网
  • start:对齐单元格的起始边缘

  • end:对齐单元格的结束边缘

  • center:单元格内部居中

  • stretch:拉伸,占满单元格的整个宽度(默认值)

stify-content 属性、align-content 属性以及 place-content 属性

justify-content 属性、align-content 属性演示地址

 属性是整个内容区域在容器里面的水平位置(左中右), 属性是整个内容区域的垂直位置(上中下)。它们都有如下的属性值。

 
     

下面以  属性为例进行讲解, 属性同理,只是方向为垂直方向

  • start - 对齐容器的起始边框
  • end - 对齐容器的结束边框
  • center - 容器内部居中
讯享网

  • space-around - 每个项目两侧的间隔相等。所以,项目之间的间隔比项目与容器边框的间隔大一倍
  • space-between - 项目与项目的间隔相等,项目与容器边框之间没有间隔
  • space-evenly - 项目与项目的间隔相等,项目与容器边框之间也是同样长度的间隔
  • stretch - 项目大小没有指定时,拉伸占据整个网格容器
 
     

grid-auto-columns 属性和 grid-auto-rows 属性

grid-auto-columns 属性和 grid-auto-rows 属性演示地址

在讲  属性和  属性之前,先来看看隐式和显示网格的概念

隐式和显示网格:显式网格包含了你在  和  属性中定义的行和列。如果你在网格定义之外又放了一些东西,或者因为内容的数量而需要的更多网格轨道的时候,网格将会在隐式网格中创建行和列

假如有多余的网格(也就是上面提到的隐式网格),那么它的行高和列宽可以根据  属性和  属性设置。它们的写法和 和  完全相同。如果不指定这两个属性,浏览器完全根据单元格内容的大小,决定新增网格的列宽和行高

讯享网

 属性和  属性只是指定了两行两列,但实际有九个元素,就会产生隐式网格。通过  可以指定隐式网格的行高为 50px

grid-column-start 属性、grid-column-end 属性、grid-row-start 属性以及grid-row-end 属性

演示地址

可以指定网格项目所在的四个边框,分别定位在哪根网格线,从而指定项目的位置

  • grid-column-start 属性:左边框所在的垂直网格线
  • grid-column-end 属性:右边框所在的垂直网格线
  • grid-row-start 属性:上边框所在的水平网格线
  • grid-row-end 属性:下边框所在的水平网格线
 
     

上面代码中,类  所在的网格项目,垂直网格线是从 2 到 4,水平网格线是从 1 到 2。其中它跟  (垂直网格线是从3 到 4,水平网格线是从 1 到 4) 是有冲突的。可以设置  去决定它们的层级关系

 

grid-area 属性

 属性指定项目放在哪一个区域,在上面介绍  的时候有提到过,这里不再具体展开,具体的使用可以参考演示地址:

grid-area 以及 grid-template-areas 属性演示地址

justify-self 属性、align-self 属性以及 place-self 属性

justify-self 属性/ align-self 属性/ place-self 属性演示地址

 属性设置单元格内容的水平位置(左中右),跟  属性的用法完全一致,但只作用于单个项目

 属性设置单元格内容的垂直位置(上中下),跟align-items属性的用法完全一致,也是只作用于单个项目

两者很相像,这里只拿  属性演示, 属性同理,只是作用于垂直方向

讯享网
  • start:对齐单元格的起始边缘

  • end:对齐单元格的结束边缘

  • center:单元格内部居中

  • stretch:拉伸,占满单元格的整个宽度(默认值)

经过上面的介绍,相信大家都可以看出,Grid 是非常强大的。一些常见的 CSS 布局,如居中,两列布局,三列布局等等是很容易实现的。我们接下来看看 Grid 布局是如何实现响应式布局的

fr 实现等分响应式

fr 实现等分响应式

 等分单位,可以将容器的可用空间分成想要的多个等分空间。利用这个特性,我们能够轻易实现一个等分响应式。 表示容器分为三等分

 
     

repeat + auto-fit——固定列宽,改变列数量

等分布局并不只有  布局才有,像  布局也能轻松实现,接下来看看更高级的响应式

上面例子的始终都是三列的,但是需求往往希望我们的网格能够固定列宽,并根据容器的宽度来改变列的数量。这个时候,我们可以用到上面提到  函数以及  关键字。 表示固定列宽为 200px,数量是自适应的,只要容纳得下,就会往上排列,代码以及效果实现如下:

演示地址

讯享网

repeat+auto-fit+minmax 去掉右侧空白

上面看到的效果中,右侧通常会留下空白,这是我们不希望看到的。如果列的宽度也能在某个范围内自适应就好了。 函数就帮助我们做到了这点。将  改成  表示列宽至少 200px,如果还有空余则一起等分。代码以及效果如下所示:

演示地址

 
     

repeat+auto-fit+minmax-span-dense 解决空缺问题

似乎一切进行得很顺利,但是某天 UI 来说,每个网格元素的长度可能不相同,这也简单,通过  关键字进行设置网格项目的跨度,,表示这个网格项目跨度为 3。具体的代码与效果如下所示:

讯享网

演示地址

不对,怎么右侧又有空白了?原来是有一些长度太长了,放不下,这个时候就到我们的  关键字出场了。 表示尽可能填充,而不留空白,代码以及效果如下所示:

 
     

最后,聊聊  布局兼容性问题,在 caniuse 中,我们可以看到的结果如下,总体兼容性还不错,但在 IE 10 以下不支持。个人建议在公司的内部系统运用起来是没有问题的,但 TOC 的话,可能目前还是不太合适

 


小讯
上一篇 2025-05-22 14:13
下一篇 2025-05-25 23:47

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/140662.html