Comment puis-je définir le premier enfant dans flexbox pleine largeur et tous les autres enfants définis sur flex:1
(pour un espace partagé)?
Comme ça:
Vous pouvez définir le :first-child
sur une largeur de 100% et le reste de l'enfant :not(:first-child)
sur flex: 1
. Pour les mettre sur plusieurs lignes, utilisez flex-wrap: wrap
sur le conteneur:
.container {
display: flex;
justify-content: space-between;
flex-wrap: wrap;
background: #e2eaf4;
padding: 10px;
}
.child {
display: inline-block;
font-family: "Open Sans", Arial;
font-size: 20px;
color: #FFF;
text-align: center;
background: #3794fe;
border-radius: 6px;
padding: 20px;
margin: 12px;
}
.child:first-child {
width: 100%;
}
.child:not(:first-child) {
flex: 1;
}
<div class="container">
<div class="child">Child</div>
<div class="child">Child</div>
<div class="child">Child</div>
</div>
Ajoutez width: 100%;
pour votre premier article. Et flex: 1;
pour les autres.
.flex {
display: flex;
flex-wrap: wrap;
}
.flex-item:not(:first-child) {
flex: 1;
}
.flex-item:nth-child(1) {
width: 100%;
}
/* Styles just for demo */
.flex-item {
background-color: #3794fe;
margin: 10px;
color: #fff;
padding: 20px;
border-radius: 5px;
}
<div class="flex">
<div class="flex-item">
Child
</div>
<div class="flex-item">
Child
</div>
<div class="flex-item">
Child
</div>
</div>