CSS网格布局中百分比和fr单位之间的差异
我正在玩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))。
如果有人能解释为什么百分比宽度会产生这样的差异,那将会很棒。
拉丁的传说