При использовании деления с calc
результат будет number
, а не integer
, поэтому он не будет работать, потому что repeat()
ожидает interger
.общая форма синтаксиса repeat()
приблизительно равна
repeat( [ <positive-integer> | auto-fill | auto-fit ] , <track-list> )
ref
И
На /
, убедитесь, что правая сторона <number>
.Если левая сторона равна <integer>
, разрешите значение <number>
.В противном случае разрешите тип левой стороны. ref
И
Числовые значения обозначены <number>
и представляют действительные числа , возможно, с дробной составляющей. ref
Даже если мы оба знаем, что результат будетбыть целым числом, браузер все равно будет рассматривать его как число.
У вас может быть та же проблема с умножением, если у вас есть число в одной из сторон
.grid {
display: grid;
grid-gap: 10px;
grid-template-columns: 1fr;
margin-bottom: 10px;
background: rgba(0, 0, 0, 0.2);
}
.grid>div {
background: tomato;
width: 20px;
text-align: center;
margin: auto;
}
.grid.no-calc {
grid-template-columns: repeat(3, 30px);
border-bottom:3px solid red;
}
.grid.multiplication {
grid-template-columns: repeat(calc(3 * 1.0), 30px); /*will fail*/
border-bottom:calc(3px * 1.0) solid red;
}
.grid.division {
grid-template-columns: repeat(calc(6 / 2), 30px);
border-bottom:calc(6px / 2) solid red; /*this will work because border accept numbers*/
}
<div class="grid no-calc">
<div>1</div>
<div>2</div>
<div>3</div>
</div>
<div class="grid multiplication">
<div>1</div>
<div>2</div>
<div>3</div>
</div>
<div class="grid division">
<div>1</div>
<div>2</div>
<div>3</div>
</div>
Firefox ведет себя по-разному и никогда не перестает работать, даже если мы явно указываем числа.Во всех случаях Fiferox будет пытаться округлить результат calc()
до положительного целого числа.
Все приведенные ниже примеры не будут работать в Chrome и будут работать в Firefox:
.grid {
display: grid;
grid-gap: 10px;
grid-template-columns: 1fr;
margin-bottom: 10px;
background: rgba(0, 0, 0, 0.2);
}
.grid>div {
background: tomato;
width: 20px;
text-align: center;
margin: auto;
}
.grid.no-calc {
grid-template-columns: repeat(calc(2.8), 30px); /*will be converted to 3*/
border-bottom:calc(calc(2.8) * 1px) solid red;
}
.grid.multiplication {
grid-template-columns: repeat(calc(3 * 1.55), 30px); /*will be converted to 4*/
border-bottom:calc(calc(3 * 1.55) * 1px) solid red;
}
.grid.division {
grid-template-columns: repeat(calc(6 / 2.8), 30px); /*will be converted to 2*/
border-bottom:calc(calc(6 / 2.8) * 1px) solid red;
}
<div class="grid no-calc">
<div>1</div>
<div>2</div>
<div>3</div>
<div>4</div>
</div>
<div class="grid multiplication">
<div>1</div>
<div>2</div>
<div>3</div>
<div>4</div>
</div>
<div class="grid division">
<div>1</div>
<div>2</div>
<div>3</div>
<div>4</div>
</div>