このページにはプロモーションが含まれています。
はじめに
今回は、CSSのレイアウトモジュールであるFlexbox(フレックスボックス)についてお話します。
Flexboxが使えると、複雑なレイアウトも簡単に組みやすくなり、
コーディングする際、柔軟に対応でき、効率的に行えます。
ぜひ一緒に使い方をマスターしましょう!
- Flexboxの書き方
- レイアウトの並べ方の種類と指定する方法
Flexboxの書き方
Flexboxでレイアウトを組む際、必要になる記述があります。
この点を覚えると、コーディングが楽になるのでぜひ習得しましょう!
Flexboxの書き方の基本形は、以下の2点です。
- 親要素にdisplay:flexを記述する
- 親要素に水平方向・垂直方向のレイアウトの指定を記述する
そうすると、子要素のレイアウトを扱えるようになります。
親要素への記述
シンプルな例で実際に見ていきましょう。
親要素「flex-container」に対して
子要素「flex-item」が3つの構造です。
<div class="flex-container"><!--親要素-->
<div class="flex-item">1</div><!--子要素1-->
<div class="flex-item">2</div><!--子要素2-->
<div class="flex-item">3</div><!--子要素3-->
</div>
.flex-container {
display: flex; /* check!! */
}
/*ここからレイアウトのためのCSSです*/
body {
margin: 0 auto;
}
.flex-container {
text-align: center;
line-height: 200px;
background-color: #eddcbc;
}
.flex-item {
width: 200px;
height: 200px;
margin: 10px;
padding: 10px;
font-size: 48px;
color: #fff;
background-color: #ff9933;
}
/*ここまでレイアウトのためのCSSです*/
data:image/s3,"s3://crabby-images/82983/82983589661ee73ae88b9ccf77d4e4bf56e0009e" alt="flexboxの画像"
親要素に「display: flex;」と記述しました。
上記の記述で、子要素の「flex-item」を簡単に横並びにできましたね!
レイアウトの並べ方の種類と指定する方法
さらにプロパティを記述することで、レイアウトの並べ方を指定できます。
レイアウトの種類をご紹介します。
- flex-direction
- flex-wrap
- justify-content
- align-items
- align-content
並ぶ向きの指定:flex-direction
プロパティflex-directionに値を与えると、
以下のように「横並び」か「縦並び」にできます。
〇〇-reverseで「逆向き」にもできます。
値 |
row(初期値) |
row-reverse |
column |
column-reverse |
row(初期値)
data:image/s3,"s3://crabby-images/1c33a/1c33a8cf3207f9e8568b9458fe6b03a2b2fe701f" alt="row(初期値)の画像"
row-reverse
data:image/s3,"s3://crabby-images/a6159/a6159bed73b16e0d47e036e4a56132fa696a1f5c" alt="row-reverseの画像"
column
data:image/s3,"s3://crabby-images/8b291/8b291e713d2acda61d2ed5a65765591b2c2e6939" alt="columnの画像"
column-reverse
data:image/s3,"s3://crabby-images/dc77c/dc77c22f892b04a86c769fcfb6c568ad7cac63b2" alt="column-reverseの画像"
折り返しの指定:flex-wrap
プロパティflex-wrapに値を与えると、
以下のように「1行に並べる」か「複数行に折り返す」かを指定できます。
値 |
nowrap(初期値) |
wrap |
wrap-reverse |
nowrap(初期値)
data:image/s3,"s3://crabby-images/74e37/74e379e5ddeaf72d9f617dba462e5dc505434257" alt="nowrap(初期値)の画像"
wrap
data:image/s3,"s3://crabby-images/65101/65101f3191d6390530ad21935c05068da6964136" alt="wrapの画像"
wrap-reverse
data:image/s3,"s3://crabby-images/82db9/82db907677b269174e73b2fd75d97aaa76a9cfa7" alt="wrap-reverseの画像"
水平方向の指定:justify-content
プロパティjustify-contentに値を与えると、
以下のように水平方向のどこに配置するかを指定できます。
値 |
flex-start(初期値) |
flex-end |
center |
space-between |
space-around |
flex-start(初期値)
data:image/s3,"s3://crabby-images/1c33a/1c33a8cf3207f9e8568b9458fe6b03a2b2fe701f" alt="row(初期値)の画像"
flex-end
data:image/s3,"s3://crabby-images/96074/960746d745780596f985a010b9ad7bc61a336b34" alt="flex-endの画像"
center
data:image/s3,"s3://crabby-images/b1307/b13073f91aab66bd8687b41bef59b176b29a2449" alt="centerの画像"
space-between
data:image/s3,"s3://crabby-images/035e2/035e254bf9a006af6fe1d5d1970e7f329d7db4b8" alt="space-betweenの画像"
space-around
data:image/s3,"s3://crabby-images/6ee11/6ee110de82ea56ee2320658a8bbcf7fc0b96bcb3" alt="space-aroundの画像"
垂直方向の指定:align-items
プロパティjustify-contentに値を与えると、
以下のように垂直方向のどこに配置するかを指定できます。
値 |
stretch(初期値) |
flex-start |
flex-end |
center |
baseline |
stretch(初期値)
data:image/s3,"s3://crabby-images/d71ff/d71ff1e8706dea1fa3baaa37843a63d152969377" alt="stretch(初期値)の画像"
flex-start
data:image/s3,"s3://crabby-images/d45d1/d45d12272989584e078988785a7cb3586a80689e" alt="flex-startの画像"
flex-end
data:image/s3,"s3://crabby-images/f86ff/f86ff8c2649d188085d3e1519d15479d89adf90b" alt="flex-endの画像"
center
data:image/s3,"s3://crabby-images/da4d4/da4d4d7e979f6f1ec2ab53f625bbee1605ff85c1" alt="centerの画像"
baseline
data:image/s3,"s3://crabby-images/2d207/2d207ed4ddf9dcae46eb5e34e583550b28701d7c" alt="baselineの画像"
複数行の揃え方の指定:align-content
プロパティalign-contentに値を与えると、
以下のように子要素が複数行の場合に、垂直方向のどこに配置するかを指定できます。
複数行の指定がある場合に適用されます。
.flex-container {
display: flex;
flex-wrap: wrap; /* 複数行に折り返す */
align-content: space-around; /* 配置の指定 */
}
値 |
stretch(初期値) |
flex-start |
flex-end |
center |
space-between |
space-around |
stretch(初期値)
data:image/s3,"s3://crabby-images/7626a/7626aeb5c0b9353e7c0aef00059ea532f7479f08" alt="stretch(初期値)の画像"
flex-start
data:image/s3,"s3://crabby-images/8bd74/8bd745af37707b1ad9e662b78dec84156b3ee9c4" alt="flex-startの画像"
flex-end
data:image/s3,"s3://crabby-images/246ea/246eade4ea2c7754f25fc1e39839dddfc888150e" alt="flex-endの画像"
center
data:image/s3,"s3://crabby-images/c8d67/c8d6750f0a9bc77592feb4c6202e29105af2a2d7" alt="centerの画像"
space-between
data:image/s3,"s3://crabby-images/3db81/3db8134bf91229e965b6122c2d350d87bad98814" alt="space-betweenの画像"
space-around
data:image/s3,"s3://crabby-images/7c1cc/7c1ccc36b33c7a96641f3a1155fb6647ea404f9b" alt="space-aroundの画像"
space-betweenは、両端寄せ(上下や左右)をして均等に配置するのに対して、
space-aroundは、両端も含めて均等に配置する
HTML/CSS おすすめの書籍
HTML/CSSの基本をもっと勉強したい方に
おすすめの本はこちらです。
おわりに
ここまで、Flexboxの様々なプロパティについて見てきました。
今回のコードを活用して、ぜひご自身でプロパティを変えて表示してみてください。
この記事が学習のお役に立てたら嬉しいです。
data:image/s3,"s3://crabby-images/b6370/b637095f23dc4e9b795257746f9ea63d70312267" alt=""
便利なFlexbox。
使ってみてください!
コメント