There are two methods you could use. One is to set the height of the flexbox using vw
. You could also use calc
if needed. Of course if the page width becomes static on wider viewports or has a max-width
set then you can use a media query to set the flexbox height in px
, em
etc.
The second method is to use padding on the flexbox child elements. Unlike margin, 100% top or bottom padding means 100% of the parent's width not height.
.flex {
display: flex;
background-color: red;
margin-bottom: 1px;
}
.flex div {
flex: 1;
background: url() center no-repeat;
background-size: 50%;
}
.flex.vw {
height: 16.67vw;
}
.flex.padding div {
padding-top: 16.67%;
}
<div class="flex vw">
<div></div>
<div></div>
<div></div>
</div>
<div class="flex padding">
<div></div>
<div></div>
<div></div>
</div>