@F1eX
React Dev

Как заставить grid всегда формировать только 2 столбца?

Нужно всегда формировать только 2 столбца у грида, независимо от количества элементов в нем.
5d9c9066b96d1462519007.png
Количество элементов в сетке изначально не известно - они генерируются динамически. Вот мой код:
.grid-container {
display: grid;
grid-template-columns: repeat(2, 1fr);
grid-auto-flow: column;
grid-template-rows: repeat(5, 1fr);
width: 30%;
grid-gap: 10px;
}
Проблема в значении счетчика в grid-template-rows: repeat(5, 1fr) - он должен подгоняться под количество элементов в сетке. Я понимаю, что можно использовать JS для подсчета дочерних элементов и с его помощью регулировать кол-во повторений в grid-template-rows, но очень надеюсь, что все это можно провернуть без скриптов.
  • Вопрос задан
  • 135 просмотров
Решения вопроса 1
В Вашем случае, чтобы ничего не считать с помощью JS, лучше вместо Grid использовать CSS Columns.

Просто задаёте количество колонок через column-count: 2; и ничего подсчитывать не нужно.
P.S. Для дочерних элементов еще задать break-inside: avoid;

Результат:
https://codepen.io/hisbvdis/pen/xxxbBNw

5d9c92b761615985366295.png
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
23 нояб. 2024, в 01:31
1000 руб./за проект
23 нояб. 2024, в 00:16
2000 руб./за проект