博客列表 >grid布局的常用属性与新单位fr

grid布局的常用属性与新单位fr

a.
a.原创
2020年12月25日 11:07:204693浏览

1. grid布局术语

1.网格容器 由若干个矩形网格单元构成
2.网格项目 网格容器的子元素,必须放在网格单元中
3.网格单元 有单元格和网格区域两种表现形式
4.网格轨道 由多个网格单元组成,根据排列方向有“行轨”和“列轨”
5.轨道间距 容器中轨道之间的间距,有行轨间距和列轨间距

使用display:grid声明网格布局

  1. body{
  2. /*声明网格布局*/
  3. display:grid;
  4. }

2. gird常用属性

编号 属性 说明
1 grid-template-columns 设置轨道的列宽
2 grid-temlate-rows 设置轨道的行高
3 gap 设置轨道间距

说明:

  1. grid-template-columns,grid-template-rows有几行几列就写几个值;
  2. gap有两个值,第一个值是水平方向,第二个值是垂直方向;

如下,设置一个两行三列布局

  1. body{
  2. display:grid;
  3. /*设置三列*/
  4. grid-template-columns:6em 7em 8em;
  5. /*设置两行*/
  6. grid-template-rows:8em 8em;
  7. /*设置间距*/
  8. gap: 0.5em 0.6em;
  9. }

3. 设置网格单元尺寸的新单位:fr

1. fr和其它单位有什么区别?

1.1 fr与auto的区别

fr可以设置比例,auto无法设置

1.2 fr和%的区别

  • 用%单位,它不将轨道间距计算在内,所以会超出容器
  • fr和%可以共存,计算方式:总宽度减去%宽度,将剩下的全部分给fr
  • auto,fr,%都是相对单位,都可以触发自动计算机制,尽可能不要同时使用

1.3 fr与其它单位混合,如em,px

px,em是固定的,计算时要先减去固定值 ,将剩下的空间在fr之间分配

1.4 fr尽可能不要和auto同时使用

会压缩auto空间

4.常用函数

1.repeat()

grid-template-rows:repeat(3,1fr)三份空间等比

2.minmax()

grid-template-rows:1fr minmax(2em,2fr) 1fr;中间行,最小宽度是2em,最大宽度是左右的2倍

5.网格单元排列与隐式轨道

什么是隐式轨道?

就是后面新增没有申明的网格单元

1.排列方式:grid-auto-flow

  • 此时默认项目在容器中按:先行后列的顺序排列,“行优先”

    2.隐式轨道的行高:grid-auto-rows

    3.隐式轨道的列宽:grid-auto-columns

  • 2和3 就是设置隐式轨道行高和列宽,非常简单和表格差不多就不演示了

6.自定义项目在容器中的显示位置

通过grid-area我们可以改变单元格显示的位置

它的语法如下:
grid-area:行起始编号 / 列起始编号/行结束编号 /列结束编号

它的参数不同意义也不同,下面是几种情况:

1.值中只有span

编号 参数 说明
1.1. 单值 跨的行数
1.2. 双值 跨的行和列数,如果只想设置列数,就必须设置行数(auto)


2.值中有span和编号

编号 参数 说明
2.1 双值 没有span,默认跨行1行1列
2.2 三值 省了列结束编号 或者跨的数量,此时前面的值可使用auto
2.3 四值 完整的语法
声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议