フレックスコンテナの中の子要素にmax-widthを適用しても効かず、幅が最少になってしまう時の対処法。
flexコンテナとmax-width
flexコンテナの中の要素(子要素や孫要素など)にmax-width
を適用することはできない。
自動で最少の幅となってしまう。width
を指定することはできる。
また、対象要素が孫要素の場合もmax-width
が適用されない。
## 適用できない事例 子要素のアイテム1とアイテム2に`max-width: 200px`を記述しているが適用されない。
![]() |
---|
.html
<p>▼子要素にmax-widthを設定</p>
<div class="flex-wrapper">
<div class="flex-item1">
<p>アイテム1</p>
</div>
<div class="flex-item2">
<p>アイテム2</p>
</div>
</div>
.scss
.flex{
&-wrapper{
display: flex;
max-width: 800px;
color:white;
}
&-item{
&1{
background: red;
max-width: 400px;
}
&2{
background: blue;
max-width: 400px;
}
}
}
**▼widthは適用される** max-widthを`width`に変更すれば適用される。
## 対処法 方法はいくつかある。一番わかりやすいのはwidthの指定で`%`を使う方法。
その他にflex-basis
を使う方法もある。
1. 収める個数が決まっている場合 calc(x%)
長さ指定ではなく、1行に2個や3個など収めたい要素の個数が決まっている場合はwidthを%
(またはcalc(X% - Ypx)
)で表せば長さが調整できるようになる。
.scss
.flex-y{
&-wrapper{
display: flex;
color:white;
max-width: 800px;
}
&-item{
&1{
background: red;
width: 50%;
}
&2{
background: blue;
width: 50%;
}
}
}
### calc(X% - Ypx)の例 calc(X% - Ypx)を使えば隙間を空けて均等に配置することができる。
親要素にjustify-content: space-between;
(値はspace-aroundやspace-evenlyなどもある)を設定し、子要素にwidth: calc(50% - 20px);
を設定した場合は以下となる。
.scss
.flex-y{
&-wrapper{
display: flex;
justify-content: space-between;
color:white;
max-width: 800px;
}
&-item{
&1{
background: red;
width: calc(50% - 20px);
}
&2{
background: blue;
width: calc(50% - 20px);
}
}
}
### 2. 子要素の場合(flex-basis) max-widthを`flex-basis`に変更する。 flex-basisはフレックスコンテナ内の要素の基本となる幅を指定するプロパティ。
画面幅を超える場合は収まるように自動調整される。
.scss
.flex-x{
&-wrapper{
display: flex;
color:white;
}
&-item{
&1{
background: red;
flex-basis: 400px;
}
&2{
background: blue;
flex-basis: 400px;
}
}
}
### 3. 孫要素の場合 孫要素が`display: inline-box`の場合もmax-widthが適用されない。
この場合は、子要素にflex-basis: 最大幅
を適用し、孫要素にwidth: 100%;
を指定する。
こうすることで、孫要素が子要素いっぱいに広がった状態になり、画面幅に合わせて子要素が伸縮する。(max-widthと同じ動きになる)
.scss
.flex{
&-wrapper{
display: flex;
color:white;
}
&-item{
&1{
background: red;
flex-basis: 400px; //子要素
}
}
&-text{
&1{
display: inline-block;
background: gold;
width: 100%; //孫要素
}
}
}
.html
<p>▼子要素にflex-basis、孫要素にwidth100%を設定</p>
<div class="flex-wrapper">
<div class="flex-item1">
<span class="flex-text1">アイテム1</span>
</div>
</div>