gpt4 book ai didi

css - 百分比和fr单位的区别

转载 作者:技术小花猫 更新时间:2023-10-29 10:19:52 25 4
gpt4 key购买 nike

我正在研究 CSS 网格布局,遇到了一个我找不到答案的问题。

考虑以下示例:

:root {
--grid-columns: 12;
--column-gap: 10px;
--row-gap: 10px;
}

.grid {
display: grid;
grid-template-columns: repeat(var(--grid-columns), calc(100% / var(--grid-columns)));
grid-column-gap: var(--column-gap);
grid-row-gap: var(--row-gap);
justify-content: center;
}

[class*=l-] {
border: 1px solid red;
}

.l-1 {
grid-column-start: span 1;
}

.l-2 {
grid-column-start: span 2;
}

.l-3 {
grid-column-start: span 3;
}

.l-4 {
grid-column-start: span 4;
}

.l-5 {
grid-column-start: span 5;
}

.l-6 {
grid-column-start: span 6;
}

.l-7 {
grid-column-start: span 7;
}

.l-8 {
grid-column-start: span 8;
}

.l-9 {
grid-column-start: span 9;
}

.l-10 {
grid-column-start: span 10;
}

.l-11 {
grid-column-start: span 11;
}

.l-12 {
grid-column-start: span 12;
}
<div class="grid">
<div class="l-6">Column 1</div>
<div class="l-6">Column 2</div>
<div class="l-3">Column 3</div>
<div class="l-4">Column 4</div>
<div class="l-3">Column 5</div>
<div class="l-2">Column 6</div>
<div class="l-1">Column 7</div>
<div class="l-10">Column 8</div>
<div class="l-1">Column 9</div>
<div class="l-5">Column 10</div>
<div class="l-5">Column 11</div>
<div class="l-2">Column 12</div>
</div>

正如您所看到的,由于使用 calc(100%/var(--grid-columns)) 设置的百分比宽度,列超出了屏幕宽度。

但是如果我使用 fr 单位,它会完美地工作:

:root {
--grid-columns: 12;
--column-gap: 10px;
--row-gap: 10px;
}

.grid {
display: grid;
grid-template-columns: repeat(var(--grid-columns), 1fr);
grid-column-gap: var(--column-gap);
grid-row-gap: var(--row-gap);
justify-content: center;
}

[class*=l-] {
border: 1px solid red;
}

.l-1 {
grid-column-start: span 1;
}

.l-2 {
grid-column-start: span 2;
}

.l-3 {
grid-column-start: span 3;
}

.l-4 {
grid-column-start: span 4;
}

.l-5 {
grid-column-start: span 5;
}

.l-6 {
grid-column-start: span 6;
}

.l-7 {
grid-column-start: span 7;
}

.l-8 {
grid-column-start: span 8;
}

.l-9 {
grid-column-start: span 9;
}

.l-10 {
grid-column-start: span 10;
}

.l-11 {
grid-column-start: span 11;
}

.l-12 {
grid-column-start: span 12;
}
<div class="grid">
<div class="l-6">Column 1</div>
<div class="l-6">Column 2</div>
<div class="l-3">Column 3</div>
<div class="l-4">Column 4</div>
<div class="l-3">Column 5</div>
<div class="l-2">Column 6</div>
<div class="l-1">Column 7</div>
<div class="l-10">Column 8</div>
<div class="l-1">Column 9</div>
<div class="l-5">Column 10</div>
<div class="l-5">Column 11</div>
<div class="l-2">Column 12</div>
</div>

用于寻找答案的资源:

如果有人能解释为什么百分比宽度会产生如此大的差异,那就太好了。

最佳答案

fr

fr 单元仅适用于容器中的可用空间。

所以在你的代码中:

grid-template-columns: repeat(12, 1fr);

...容器中的可用空间平均分布在 12 列中。

由于列只处理可用空间grid-column-gap 不是一个因素。它是在确定 fr 长度 ( spec reference ) 之前从容器宽度中减去的。

浏览器的计算方式如下:

(free space - gutters) / 12  = 1fr

%

当您使用百分比时...

grid-template-columns: repeat(12, calc(100% / 12));

... 容器被分成 12 列,每列的宽度为 8.33333%。这是一个实际长度,与 fr 单元不同,它只处理空闲空间。

列长度和网格间隙都计入宽度。

浏览器的计算方式如下:

8.33333% * 12 = 100%
+
11 * 10px = 110px

明显溢出。

(注意:grid-*-gap 属性只适用于网格项之间——从不适用于项和容器之间。这就是为什么网格间隙的数量是 11,而不是 13。)

这个有效:

grid-template-columns: repeat(12, calc(8.3333% - 9.1667px));

分解为:

  • 12 列

  • 每列的宽度由容器的整个宽度 (100%) 除以 12 决定

    100% / 12 = 8.3333% (individual column width)
  • 然后减去列间隙(有11个)

     10px * 11 = 110px (total width of column gaps)

    110px / 12 = 9.1667px (amount to be deducted from each column)

.grid {
display: grid;
grid-template-columns: repeat(12, calc(8.3333% - 9.1667px));
grid-column-gap: 10px;
grid-row-gap: 10px;
justify-content: center;
}

.l-1 { grid-column-start: span 1; }
.l-2 { grid-column-start: span 2; }
.l-3 { grid-column-start: span 3; }
.l-4 { grid-column-start: span 4; }
.l-5 { grid-column-start: span 5; }
.l-6 { grid-column-start: span 6; }
.l-7 { grid-column-start: span 7; }
.l-8 { grid-column-start: span 8; }
.l-9 { grid-column-start: span 9; }
.l-10 { grid-column-start: span 10; }
.l-11 { grid-column-start: span 11; }
.l-12 { grid-column-start: span 12; }
[class*=l-] { border: 1px solid red; }
<div class="grid">
<div class="l-6">Column 1</div>
<div class="l-6">Column 2</div>
<div class="l-3">Column 3</div>
<div class="l-4">Column 4</div>
<div class="l-3">Column 5</div>
<div class="l-2">Column 6</div>
<div class="l-1">Column 7</div>
<div class="l-10">Column 8</div>
<div class="l-1">Column 9</div>
<div class="l-5">Column 10</div>
<div class="l-5">Column 11</div>
<div class="l-2">Column 12</div>
</div>

关于css - 百分比和fr单位的区别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45090726/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com