Flexboxで均等幅(同じサイズ)で横並び配置する方法!

  • Flexboxで子要素(flexアイテム)の大きさを均等幅(同じサイズ)にしたい

この記事ではサンプルを用いてFlexboxで子要素(flexアイテム)の大きさを均等幅(同じサイズ)にする方法を紹介します。

この記事はお悩み解決系の記事なので、Flexboxに関する理解を深めたい方は下の記事をご覧ください。

Flexboxの使い方をどこよりも詳しく解説!図解やサンプルもあり!

この記事の目次

均等幅(同じサイズ)で配置するには flex: 1;を使うだけ!

均等幅の図

図のようにflexアイテムを均等に配置する方法となぜ均等になるのかを解説します。

<div class ="flex-container">
    <div class ="flex-item">1</div>
    <div class ="flex-item">2</div>
    <div class ="flex-item">3</div>
</div>
.flex-container {
    display: flex;
    ...
}

.flex-item {
    flex: 1; /* これが重要! */
    ...
}

このようにflexアイテムに対して、flex: 1;を指定するだけで、flexアイテムの個数に限らず均等幅(同じサイズ)になります。

たったこれだけなのでコピペして使えますが、なぜこうなるかも理解してみてください。次のセクションでなぜ均等幅になるか解説します。

なぜflex: 1;で均等幅(同じサイズ)で配置されるのか

flexプロパティは、flex-grow / flex-shrink / flex-basisの3つをまとめて指定出来るプロパティです。

flexプロパティの初期値は0 1 autoですが、数値だけを指定すると、n 1 0になります。(nが指定した数値)

/* flex: 1;と同じ */
.flex-item {
    flex-grow: 1;
    flex-shrink: 1;
    flex-basis: 0;
}

つまり、flex: 1;は上の指定をしていることになります。

ポイントはflex-basis: 0;です。flexアイテムは全て幅が0だと想定されて、余ったスペースが分配されます。『flex アイテムは全て幅が0 = 余ったスペースはflexコンテナの幅そのもの』になります。

余ったスペース(= flex コンテナの幅そのもの)を均等にflexアイテムに分配していることになるので、flexアイテムは均等幅になります。

flexアイテムの幅が0想定なのでflexアイテムがflexコンテナに収まりきらないことはあり得ません。従ってflex-shrinkの値はなんの影響も与えません。

また、flex-growは全てのflexアイテムに共通で指定すれば数値はなんでも良いので、flex: 5;でもflex: 100;でも均等幅になります。

自由な比率で幅を決めるのも簡単!

flex: 1;で均等幅(同じサイズ)で配置され理由が理解できれば、2:1 や 4:3 など、自由な比率でflexアイテムの幅を決めることも簡単です。

2:1の幅の図

上の図は2:1の比率の幅になっています。

.flex-item:nth-child(1) {
    flex: 2;
}

.flex-item:nth-child(2) {
    flex: 1;
}

どちらもflex-basis: 0;なので、flexアイテムは幅が0だと想定されて、余ったスペースを2:1で分配しています。

URLなど長い英語の文字列が入る場合は注意!

.flex-item {
    ...
    word-wrap: break-word;
    min-width: 0;
}

URLなど長い英語の文字列が入る場合、上の2行をプラスしましょう。この2行がないと英語の文字列が折り返さずにおかしなことになります。

制作時に英語の文字列が入らなくても、その後文章差し替え等で入る可能性も考慮して、必ず入れておいても良いと思います。

他にもFlexbox関連の記事を上げています!

レイアウトを作るにはFlexboxの理解が必須です。基礎を学びたい方は下記の記事をご覧ください。

Flexboxの使い方をどこよりも詳しく解説!図解やサンプルもあり!

Flexboxでもレイアウトは作れますが、デザインによってはCSS Gridの方が適している場合もあります。CSS Gridの使い方は下記の記事をご覧ください。

【CSS Grid入門】図解も交えて使い方を詳しく解説!

この記事のように、知っておくと便利なFlexbox関連の記事も多数あげています。

Flexboxで最後の1つだけ右寄せや下寄せにする方法! Flexboxで画像や要素が小さくなる(潰れる)時の対処方法! Flexboxで画像が縦に伸びる(比率がおかしい)時の対処方法!

カラクリ無しの完全無料!あなた専属のメンターが付く?

先着制で受講料98,000円が0円になる、1ヶ月無料のスクール 『ZeroPlus Gate』 を知っていますか?

入会金がかかる...。2ヶ月目から有料...。契約期間の縛りがある...。そのような、スクールではありません。本当に一切費用がかからないスクールです。

  • flex / gridで詰まる...
  • デザインを再現できない...
  • 現役のプロからアドバイスをもらいたい...

↑こんな方は、利用してみてはいかがでしょうか?

先着制で98,000円→0円

無料で受講する

本当に無料なので迷わずGO💨

この記事を書いた人

Gakuのアイコン

Gaku /

フリーランス8年を経て法人化(4期目)。コンテンツ制作、ライティング、マーケティング、デザイン、コーディング、プログラミングなど、幅広くやってます!

【先着制】30日間完全無料のスクール👉

詳しく見る
模写修行のトップページのスクリーンショット

完全無料のコーディング練習サイト