Anda harus menggunakan properti flexatau flex-basisbukan width. Baca lebih lanjut tentang MDN .
.flexbox .red {
flex: 0 0 25em;
}
The flexproperti CSS adalah properti singkatan menentukan kemampuan item fleksibel untuk mengubah dimensi untuk mengisi ruang yang tersedia. Itu mengandung:
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 */
Demo sederhana menunjukkan cara mengatur kolom pertama ke 50pxlebar tetap.
.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>
Lihat codepen yang diperbarui berdasarkan pada kode Anda.
flex-shrink, terima kasih, jawaban yang bagus.