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))
。
如果有人能解释为什么百分比宽度会产生这样的差异,那将会很棒。
拉丁的传说