CSS grid-template-columns属性探讨|给你代码

yumo6667小时前技术文章3

CSSgrid布局


CSS grid布局是一种很强大的布局,兼容性如上表所示,表现在控制台里,你可以清楚看到他的内部每一个块都由一个虚线方块组成。他的每行每列都会生产一个单元格,而划分他们之间的线称为网格线。我这次就主要讲述其中两个属性。

内容

1.grid-template-columns(rows), 他可以的定义网格列或者行的维度大小,在属性数值上,除了比较常用的属性,还支持fr,flex弹性系数,可以根据该数值比例来分配剩余空间。还有[xx]在属性数值里定义网格线的名称,方便以后再次引用他。还有repeat属性。


如图所示的样式,是类似列表一样有很多重复的模块,就可以用到repeat属性来进行重复。

repeat(5, 250px);类似这样的属性数值。那么我就想了,如果只是这样,普通的布局也能实际,为啥要用这个repeat呢。如果我想自适应宽度变化可以吗?答案是支持的。repeat还支持auto-fill, auto-fit这2个属性能进行自动填充,配合minmax属性可以实现根据宽度进行子列表的自适应布局。如:repeat(auto-fill, minmax(100px, 1fr)); 代表了自动填充,minmanx最小值,配合flex分配空间。

关于autfo-fit,autofill的区别在mdn上有解释,但是可能难理解,直接利用mdn上2个例子。

grid-template-columns: repeat(auto-fill, minmax(10px, 1fr));


grid-template-columns: repeat(auto-fit, minmax(10px, 1fr));


可以清楚的看到,在网格不能填满一行的时候,auto-fit会尽可能的让元素去填满他,也就是说剩余的空间会被分配到每个元素上,而auto-fill还是按照原来的布局,模拟元素可以填满一行的情况。

2.grid-gap设置网格行和列之间的间隙大小

兼容情况如下图所示:

根据mdn文档,实验中的功能gap(grid-gap)属性也被flex布局所支持。但是兼容性应该不好太好。


gap属性有什么用呢?


如上图布局,如果支持gap,那么只要之间写一个gap: 1px就可以了。不然的话,就比较繁琐了,只能利用边距去实现。

总结

css grid还有很多属性可以用来布局元素,本文仅仅只是讲到了一小点。它在现代浏览器中的支持度还是不错的,可以多多用它。如果支持的浏览器兼容性不是太好的话,只能用其他东西来代替它了。


给你代码|往期回顾:

给你代码:短链接生成原理

给你代码:网站图标favicon自动抓取

给你代码:chrome插件心得


相关文章

图解 CSS Grid 布局(css的grid布局)

大家好,我是 Echa。Grid(网格)布局是最强大的 CSS 布局方案,用于构建二维布局。Grid 布局将页面划分成一个个网格,可以任意组合不同的网格,实现各种各样的布局。下面就来看看 CSS Gr...

从零开始的Grid布局掌握(grid布局和flex布局发展趋势)

前言在上一篇文章中,我们了解了Flex布局系统的强大功能和灵活性,其能够帮我们轻松地控制和对齐页面中的元素然而,在实际的网页设计中,我们经常会遇到更加复杂的布局需求,例如创建多列、多行的网格结构,为了...

CSS粘性页脚布局:从Flexbox到Grid的现代实现指南

一个让前端新手怀疑人生的"简单"需求"CSS有什么难的?"——这话大概是每个前端开发者入行前的天真想法。直到遇到第一个"粘性页脚"需求:当页面内容不足时...

用 CSS Grid 布局制作一个响应式柱状图

最新一段时间比较喜欢玩弄图表,出于好奇,我想找出比较好的用 CSS 制作图表的方案。开始学习网上开源图表库,它对我学习新的和不熟悉的前端技术很有帮助,比如这个:CSS Grid。今天和大家分享我学到的...

CSS布局模式之Flex布局&Grid布局

1. 简介1.1 什么是CSS布局?CSS布局(Cascading Style Sheets layout)指的是通过使用CSS样式来控制网页中元素的布局方式。在网页设计中,布局是非常重要的一个方面,...

别再纠结了!Grid和Flexbox终极指南

还在为页面布局头疼吗?面对Flexbox和Grid,你是否也曾陷入“到底该用谁”的迷思?别再把它们当成竞争对手了,它们其实是帮你搞定布局的黄金搭档!记住一个核心原则:**一维用Flex,二维用Grid...