前回に引き続きflexboxについて簡単にまとめてみたいと思います。今回は、左寄せや上寄せ等、位置揃えがテーマです。
横方向の配置
横方向の配置はjustify-content
の値で設定できます。
.flex-row {
width: 100%;
height: 50px;
display: flex;
flex-direction: row;
}
左寄せ
justify-content: flex-start
とします。
<div class="flex-row" style="justify-content: flex-start">
<div style="width: 20%">1</div>
<div style="width: 20%">2</div>
<div style="width: 20%">3</div>
<div style="width: 20%">4</div>
</div>
data:image/s3,"s3://crabby-images/7b749/7b749b574ef6d45388add5f6650821dc7acd16b3" alt="flexbox2 その1"
※灰色の部分は<div class="flex-row">
の外側、白色の部分は<div class="flex-row">
の内側でどの要素も表示していないスペース(余白)部分になります。
右寄せ
justify-content: flex-end
とします。
<div class="flex-row" style="justify-content: flex-end">
<div style="width: 20%">1</div>
<div style="width: 20%">2</div>
<div style="width: 20%">3</div>
<div style="width: 20%">4</div>
</div>
data:image/s3,"s3://crabby-images/da292/da2920c9c4c8122cad16c083d970fbcdbfcff558" alt="flexbox2 その2"
中央揃え
justify-content: center
とします。
<div class="flex-row" style="justify-content: center">
<div style="width: 20%">1</div>
<div style="width: 20%">2</div>
<div style="width: 20%">3</div>
<div style="width: 20%">4</div>
</div>
data:image/s3,"s3://crabby-images/2a318/2a3183e89fb715cf95770d19f1e484608c619aee" alt="flexbox2 その3"
スペース(余白)が均等になるように配置
スペース(余白)が均等になるように配置する場合はjustify-content: space-between
を使います。
<div class="flex-row" style="justify-content: space-between">
<div style="width: 20%">1</div>
<div style="width: 20%">2</div>
<div style="width: 20%">3</div>
<div style="width: 20%">4</div>
</div>
data:image/s3,"s3://crabby-images/32d0d/32d0d68f4561d5834e740bbcd53ad1a42ac2fb6f" alt="flexbox2 その4"
両端にもスペース(余白)を配置する場合はjustify-content: space-around
を使います。
<div class="flex-row" style="justify-content: space-around">
<div style="width: 20%">1</div>
<div style="width: 20%">2</div>
<div style="width: 20%">3</div>
<div style="width: 20%">4</div>
</div>
data:image/s3,"s3://crabby-images/9ff71/9ff7135b0a0286be8c7617575ffc3d41a404cfa0" alt="flexbox2 その5"
縦方向の配置
縦方向の配置はalign-items
の値で設定できます。
.flex-column {
width: 100%;
height: 200px;
display: flex;
flex-direction: column;
}
上寄せ
上寄せで配置する場合はalign-items: flex-start
を使います。
<div class="flex-row" style="align-items: flex-start; height: 200px">
<div style="flex-grow: 1; height: 50px">1</div>
<div style="flex-grow: 1; height: 200px">2</div>
<div style="flex-grow: 1; height: 150px">3</div>
<div style="flex-grow: 1; height: 100px">4</div>
</div>
data:image/s3,"s3://crabby-images/398c4/398c4dc08c4f35113c359e974e0ea63b6a008698" alt="flexbox2 その6"
下寄せ
下寄せで配置する場合はalign-items: flex-end
を使います。
<div class="flex-row" style="align-items: flex-end; height: 200px">
<div style="flex-grow: 1; height: 50px">1</div>
<div style="flex-grow: 1; height: 200px">2</div>
<div style="flex-grow: 1; height: 150px">3</div>
<div style="flex-grow: 1; height: 100px">4</div>
</div>
data:image/s3,"s3://crabby-images/8fd34/8fd342b207acc9837db765bb03f2d9f15e5ce677" alt="flexbox2 その7"
中央に揃え
中央に揃えて配置する場合はalign-items: center
を使います。
<div class="flex-row" style="align-items: center; height: 200px">
<div style="flex-grow: 1; height: 50px">1</div>
<div style="flex-grow: 1; height: 200px">2</div>
<div style="flex-grow: 1; height: 150px">3</div>
<div style="flex-grow: 1; height: 100px">4</div>
</div>
data:image/s3,"s3://crabby-images/f2577/f2577977ef8d8a1c5830d94876f01128f8d8d2c9" alt="flexbox2 その8"
サンプル
この記事で紹介したサンプルコードは下記でご覧になれます。
CSS3のflexboxを使ったサンプル その2