Вам следует использовать свойство flex
или, flex-basis
а не width
. Узнайте больше на MDN .
.flexbox .red {
flex: 0 0 25em;
}
Свойство flex
CSS - это сокращенное свойство, определяющее способность гибкого элемента изменять свои размеры для заполнения доступного пространства. Это содержит:
flex-grow: 0; /* do not grow - initial value: 0 */
flex-shrink: 0; /* do not shrink - initial value: 1 */
flex-basis: 25em; /* width/height - initial value: auto */
Простая демонстрация показывает, как установить 50px
фиксированную ширину для первого столбца .
.flexbox {
display: flex;
}
.red {
background: red;
flex: 0 0 50px;
}
.green {
background: green;
flex: 1;
}
.blue {
background: blue;
flex: 1;
}
<div class="flexbox">
<div class="red">1</div>
<div class="green">2</div>
<div class="blue">3</div>
</div>
См. Обновленный код на основе вашего кода.
flex-shrink
, спасибо, хороший ответ.Если кто-то хочет иметь гибкий флексбокс с процентами (%), это намного проще для медиа-запросов.
flex-basis: 25%;
При тестировании это будет намного плавнее.
// VARIABLES $screen-xs: 480px; $screen-sm: 768px; $screen-md: 992px; $screen-lg: 1200px; $screen-xl: 1400px; $screen-xxl: 1600px; // QUERIES @media screen (max-width: $screen-lg) { flex-basis: 25%; } @media screen (max-width: $screen-md) { flex-basis: 33.33%; }
источник