CSS辞典 flex-flowプロパティ、flex-directionプロパティ、flex-wrapプロパティの解説
フレックスアイテムの配置方向と折り返しを一括して指定する「flex-flow」プロパティ、フレックスアイテムの設置方向を指定する「flex-direction」プロパティ、フレックスアイテムの折り返しを指定する「flex-wrap」プロパティの使用方法を記載
対応バージョン:CSS3/2.1
対応ブラウザ
data:image/s3,"s3://crabby-images/07604/07604da0bff51214124e04f13efc27bfe59a21be" alt="ruby要素,rb要素,rt要素、rp要素、rtc要素 対応ブラウザ:chrome"
data:image/s3,"s3://crabby-images/fb3b4/fb3b46372d27f0bc36d573c070dca31d88bb5221" alt="ruby要素,rb要素,rt要素、rp要素、rtc要素 対応ブラウザ:firefox"
data:image/s3,"s3://crabby-images/fedeb/fedebedc0dfca9b8099f518641a50dbb266e894c" alt="ruby要素,rb要素,rt要素、rp要素、rtc要素 対応ブラウザ:safari"
data:image/s3,"s3://crabby-images/0dd5d/0dd5d3b6580f8a095a0ef724d993fbbdc8e618db" alt="ruby要素,rb要素,rt要素、rp要素、rtc要素 対応ブラウザ:ms edge"
data:image/s3,"s3://crabby-images/4db8d/4db8d0f6cb6284560934a9604e71d1897441e865" alt="ruby要素,rb要素,rt要素、rp要素、rtc要素 対応ブラウザ:ms ie"
data:image/s3,"s3://crabby-images/d1039/d1039816042d60fbbdbe7b912a5f228019b26f9b" alt="ruby要素,rb要素,rt要素、rp要素、rtc要素 対応ブラウザ:opera"
flex-flowプロパティ
初期値 | 各プロパティに従う |
適用される要素 | 段組みされた要素 |
モジュール | CSS Multi-column Layout Module |
継承 | なし |
概要・使用方法
{ flex-flow: -direction -wrap;}
flex-flowプロパティは、フレックスアイテムの配置方向と折り返しを一括で指定することができます。
指定できる値は各プロパティと同様です。半角スペースで区切って指定できます。順序は順不同です。
フレキシブルボックスレイアウトの概念は「displayプロパティ」を参照
指定できる値
flex-directionプロパティとflex-wrapプロパティと同様です。
サンプルコード
<!DOCTYPE html>
<html lang="ja">
<head>
<title>flex-flowプロパティ CSSフォントサンプルページ</title>
<meta charset="uft-8">
<style>
.flex-flow-sample-flex1{
height:200px;
display: flex;
flex-flow:column wrap;
}
.flexbox-item1{
width:300px;
height:25px;
background-color:teal;
margin:10px;
padding:25px;
text-align:center;
}
.flexbox-item2{
width:300px;
height:25px;
background-color:silver;
margin:10px;
padding:25px;
text-align:center;
}
</style>
</head>
<body>
<h1> nowrap</h1>
<div class="flex-flow-sample-flex1">
<div class="flexbox-item1">フレックスボックスアイテム1</div>
<div class="flexbox-item2">フレックスボックスアイテム2</div>
<div class="flexbox-item1">フレックスボックスアイテム3</div>
<div class="flexbox-item2">フレックスボックスアイテム4</div>
</div>
</body>
</html>
nowrap
chromeブラウザ実行結果
data:image/s3,"s3://crabby-images/ccc01/ccc0125572ad3991c37f19c38a2d24daca796bc3" alt="chrome"
Firefox ブラウザ実行結果
data:image/s3,"s3://crabby-images/bbdf6/bbdf6534c52a6136f7f3c3c4bb214a3215ebfb80" alt="Firefox"
edgeブラウザ実行結果
data:image/s3,"s3://crabby-images/a0881/a0881d3fb51cd56781a5e357c3f3c90e0155db98" alt="edge"
operaブラウザ実行結果
data:image/s3,"s3://crabby-images/4a92f/4a92fa24efac6949b68a18fd60abfe3c2e6b9932" alt="opera"
flex-directionプロパティ
初期値 | row |
適用される要素 | フレックスコンテナ |
モジュール | CSS Flexible Box Layout Module Level1 |
継承 | なし |
概要・使用方法
{ flex-direction: 方向;}
flex-directionプロパティは、フレックスコンテナのメイン軸の方向を指定することで、フレックスアイテムの配置方向を指定します。
指定できる値
指定できる値は各プロパティと同様です。半角スペースで区切って指定できます。順序は順不同です。
row(初期値) | メイン軸の方向に、フレックスボックスアイテムを左から右に配置されます。 |
row-reverse | メイン軸の方向に、フレックスボックスアイテムは右から左へ配置されます。 |
column | クロス軸の方向に、フレックスボックスアイテムを上から下に指定する。 |
column-reverse | クロス軸の方向に、フレックスボックスアイテムを下から上に指定する。 |
サンプルコード
<!DOCTYPE html>
<html lang="ja">
<head>
<title>flex-directionプロパティ CSSフォントサンプルページ</title>
<meta charset="uft-8">
<style>
.sample-flex1{
display: flex;
flex-direction:row;
}
.sample-flex2{
display: flex;
flex-direction:row-reverse;
}
.sample-flex3{
display: flex;
flex-direction:column;
}
.sample-flex4{
display: flex;
flex-direction:column-reverse;
}
.flexbox-item1{
width:300px;
height:25px;
background-color:teal;
margin:10px;
padding:25px;
text-align:center;
}
.flexbox-item2{
width:300px;
height:25px;
background-color:silver;
margin:10px;
padding:25px;
text-align:center;
}
</style>
</head>
<body>
<h1> flex-direction:row;</h1>
<div class="sample-flex1">
<div class="flexbox-item1">フレックスボックスアイテム1</div>
<div class="flexbox-item2">フレックスボックスアイテム2</div>
<div class="flexbox-item1">フレックスボックスアイテム3</div>
<div class="flexbox-item2">フレックスボックスアイテム4</div>
</div>
<h1> flex-direction:row-reverse;</h1>
<div class="sample-flex2">
<div class="flexbox-item1">フレックスボックスアイテム1</div>
<div class="flexbox-item2">フレックスボックスアイテム2</div>
<div class="flexbox-item1">フレックスボックスアイテム3</div>
<div class="flexbox-item2">フレックスボックスアイテム4</div>
</div>
<h1> flex-direction:row-reverse;</h1>
<div class="sample-flex3">
<div class="flexbox-item1">フレックスボックスアイテム1</div>
<div class="flexbox-item2">フレックスボックスアイテム2</div>
<div class="flexbox-item1">フレックスボックスアイテム3</div>
<div class="flexbox-item2">フレックスボックスアイテム4</div>
</div>
<h1> flex-direction:row-reverse;</h1>
<div class="sample-flex4">
<div class="flexbox-item1">フレックスボックスアイテム1</div>
<div class="flexbox-item2">フレックスボックスアイテム2</div>
<div class="flexbox-item1">フレックスボックスアイテム3</div>
<div class="flexbox-item2">フレックスボックスアイテム4</div>
</div>
</body>
</html>
flex-direction:row;
flex-direction:row-reverse;
flex-direction:row-reverse;
flex-direction:row-reverse;
chromeブラウザ実行結果
data:image/s3,"s3://crabby-images/4c2f5/4c2f53a252ed98a79f1173eb32a4a7287948377c" alt="chrome"
Firefox ブラウザ実行結果
data:image/s3,"s3://crabby-images/3c65a/3c65adff422686a6863f022fa91385644903295e" alt="Firefox"
edgeブラウザ実行結果
data:image/s3,"s3://crabby-images/cf466/cf46653e291a8d754cd632e3d4a7bb44accb03db" alt="edge"
operaブラウザ実行結果
data:image/s3,"s3://crabby-images/5156b/5156ba4ab121a8960d3a64cbce0d68215e58e247" alt="opera"
flex-wrapプロパティ
初期値 | nowrap |
適用される要素 | フレックスコンテナ |
モジュール | CSS Flexible Box Layout Module Level1 |
継承 | なし |
概要・使用方法
{ flex-wrap: 折り返し;}
flex-wrapプロパティは、フレックスアイテムの折り返しを指定します。また、折り返す場合の方向も指定できます。
指定できる値
指定できる値は各プロパティと同様です。半角スペースで区切って指定できます。順序は順不同です。
nowrap | フレックスアイテムは折り返されず、1行で表示されます。 |
wrap | フレックスアイテムは折り返され、複数行で表示されます。通常は上から下に折り返され2行目以降のアイテムは左から右に配置されます。 |
wap-reverse | フレックスアイテムは折り返され、複数行で表示されます。ただし、wrapとは逆に、下から上に折り返されます。 |
サンプルコード
<!DOCTYPE html>
<html lang="ja">
<head>
<title>flex-wrapプロパティ CSSフォントサンプルページ</title>
<meta charset="uft-8">
<style>
.wrap-sample-flex1{
display: flex;
flex-direction:row;
flex-wrap:nowrap;
}
.wrap-sample-flex2{
display: flex;
flex-direction:row;
flex-wrap:wrap;
}
.wrap-sample-flex3{
display: flex;
flex-direction:row;
flex-wrap:wrap-reverse;
}
.flexbox-item1{
width:300px;
height:25px;
background-color:teal;
margin:10px;
padding:25px;
text-align:center;
}
.flexbox-item2{
width:300px;
height:25px;
background-color:silver;
margin:10px;
padding:25px;
text-align:center;
}
</style>
</head>
<body>
<h1> nowrap</h1>
<div class="wrap-sample-flex1">
<div class="flexbox-item1">フレックスボックスアイテム1</div>
<div class="flexbox-item2">フレックスボックスアイテム2</div>
<div class="flexbox-item1">フレックスボックスアイテム3</div>
<div class="flexbox-item2">フレックスボックスアイテム4</div>
</div>
<h1>wrap</h1>
<div class="wrap-sample-flex2">
<div class="flexbox-item1">フレックスボックスアイテム1</div>
<div class="flexbox-item2">フレックスボックスアイテム2</div>
<div class="flexbox-item1">フレックスボックスアイテム3</div>
<div class="flexbox-item2">フレックスボックスアイテム4</div>
</div>
<h1>wrap-reverse</h1>
<div class="wrap-sample-flex3">
<div class="flexbox-item1">フレックスボックスアイテム1</div>
<div class="flexbox-item2">フレックスボックスアイテム2</div>
<div class="flexbox-item1">フレックスボックスアイテム3</div>
<div class="flexbox-item2">フレックスボックスアイテム4</div>
</div>
</body>
</html>
nowrap
wrap
wrap-reverse
chromeブラウザ実行結果
data:image/s3,"s3://crabby-images/93be9/93be9ef6a8a854f6a55e494b895e18ed03b548c2" alt="chrome"
Firefox ブラウザ実行結果
data:image/s3,"s3://crabby-images/937da/937da8698bc182cacf99aae748f85e0d101646fd" alt="Firefox"
edgeブラウザ実行結果
data:image/s3,"s3://crabby-images/e3670/e36706b695b99785c5124c66958def851b8432f9" alt="edge"
operaブラウザ実行結果
data:image/s3,"s3://crabby-images/72383/723836666d4172cda15ad1fcf28e9222083054e8" alt="opera"