data:image/s3,"s3://crabby-images/871df/871df169bdc49d7e8f4aa060b977df8d7c311f4c" alt="とりとん"
flexboxのプロパティめっちゃある!
最近HP作成の依頼でかなりflexを多用する機会があったので、備忘録として。
これは要素を横並びにするとても便利で主流な手法なので今更ですが、誰かの参考になれば幸いです。
flexコンテナとflexアイテム
基本的な使い方としては、横並びにしたい子要素を親要素のdivで囲み、cssで親要素に「display: flex;」記述するだけでOKです!
flexboxの親要素を「flex container」子要素を「flex item」といいます。
基本的なHTMLとCSSの記述下記の通りです!
data:image/s3,"s3://crabby-images/95197/95197a365d88c38d66d469b3b195a95aff16a78e" alt=""
<div class="parent">
<div class="child_1">1</div>
<div class="child_2">2</div>
<div class="child_3">3</div>
<div class="child_4">4</div>
<div class="child_5">5</div>
</div>
.parent{
display: flex;
width: 300px;
height: 150px;
background-color: #f5deb3;
}
.child_1,.child_2,.child_3,.child_4,.child_5{
font-size: 30px;
padding: 2px 3px;
margin: 10px;
color: #ffffff;
border: double 5px #B8860B;
background-color: #DEB887;
}
親要素:flexコンテナのプロパティ
親要素に記述することで子要素の位置を指定することができるプロパティをまとめてみました!
flex-direction:子要素の並び順
row(初期値)
data:image/s3,"s3://crabby-images/2509d/2509dee2785ee66869d61c0ccab00edeb02a429b" alt=""
左から並べる
column
data:image/s3,"s3://crabby-images/b8548/b8548cfc20c32b3bf3cac834e697623b77660f71" alt=""
上から並べる
row-reverse
data:image/s3,"s3://crabby-images/921d5/921d5fb861fbe79e6e93e0e43d4b1adecef0fe94" alt=""
右から並べる
column-reverse
data:image/s3,"s3://crabby-images/8b29b/8b29b6bb4fdd34a05c058f0f81bc9ce0e2d99efa" alt=""
下から並べる
See the Pen JjRBapw by とりとん (@darakerutoriton) on CodePen.
See the Pen flex-direction : column; by とりとん (@darakerutoriton) on CodePen.
See the Pen flex-direction : row-reverse; by とりとん (@darakerutoriton) on CodePen.
See the Pen flex-direction : column-reverse; by とりとん (@darakerutoriton) on CodePen.
flex-wrap:子要素の折り返し
nowrap(初期値)
data:image/s3,"s3://crabby-images/39b92/39b92144edd6ef866e9ca2ebcc204f08bb93651b" alt=""
親要素に関係なく1行に並べる
wrap
data:image/s3,"s3://crabby-images/f60d6/f60d65d9b46ccada769a684aadd6aaf713e653d9" alt=""
親要素に合わせて下へ折り返す
wrap-reverse
data:image/s3,"s3://crabby-images/58e09/58e093f548cb6f5d33cf5b95716d6c1dec19d10b" alt=""
親要素に合わせて上へ折り返す
See the Pen flex-wrap: no-wrap; by とりとん (@darakerutoriton) on CodePen.
See the Pen flex-wrap: wrap; by とりとん (@darakerutoriton) on CodePen.
See the Pen YzGjJqq by とりとん (@darakerutoriton) on CodePen.
■ flex-flow
子要素の並び順と折り返しは、まとめて記述することができます(例)⬇️
See the Pen flex-flow: column wrap; by とりとん (@darakerutoriton) on CodePen.
justify-content:子要素の横位置
flex-start(初期値)
data:image/s3,"s3://crabby-images/813a7/813a73e6ea03b7aa8656f6dd6e56ee76a7a8af22" alt=""
左寄せ
flex-end
data:image/s3,"s3://crabby-images/b8fba/b8fbae3bf5816178e566be7287e7d3aa3d5e2a2b" alt=""
右寄せ
center
data:image/s3,"s3://crabby-images/991c5/991c57ca0d5037a0108940747cbd1637fe4cfba9" alt=""
中央寄せ
space-between
data:image/s3,"s3://crabby-images/b4b6b/b4b6b245a23efae6eb23b90b7b992bc3ed91d591" alt=""
子要素の横幅に均等の余白
space-around
data:image/s3,"s3://crabby-images/18f91/18f9101eb79169d481679f40c03e7000c924ef6a" alt=""
均等の余白+端に半分の余白
See the Pen justify-content: flex-start; by とりとん (@darakerutoriton) on CodePen.
See the Pen justify-content: flex-end; by とりとん (@darakerutoriton) on CodePen.
See the Pen justify-content: center; by とりとん (@darakerutoriton) on CodePen.
See the Pen justify-content: space-between; by とりとん (@darakerutoriton) on CodePen.
See the Pen justify-content: space-around; by とりとん (@darakerutoriton) on CodePen.
align-items:子要素の縦位置
flex-start
data:image/s3,"s3://crabby-images/fdcdd/fdcdd6dc802e06d8d8dca0745c9b7999ce5faa79" alt=""
上寄せ
flex-end
data:image/s3,"s3://crabby-images/00070/0007095b3761288e634ac71b8946252f98743798" alt=""
下寄せ
center
data:image/s3,"s3://crabby-images/caf33/caf337612868f3210b3a851c857bc872b0edadf0" alt=""
中央寄せ
stretch(初期値)
data:image/s3,"s3://crabby-images/f157b/f157baed394839449a0eaa79a2c3d265710d02d4" alt=""
親要素の縦幅に合わせる
baseline
data:image/s3,"s3://crabby-images/140bc/140bc2a34cc4f583d3683f70dc2aa362be00f39a" alt=""
テキストの下線に揃える
See the Pen align-items: flex-start; by とりとん (@darakerutoriton) on CodePen.
See the Pen align-items: flex-end; by とりとん (@darakerutoriton) on CodePen.
See the Pen align-items: center; by とりとん (@darakerutoriton) on CodePen.
See the Pen align-items: stretch; by とりとん (@darakerutoriton) on CodePen.
See the Pen align-items: baseline; by とりとん (@darakerutoriton) on CodePen.
align-content:複数行の縦位置
flex-start
data:image/s3,"s3://crabby-images/31201/312018ab32c78af13ebd9454d5fd944092c0a7fe" alt=""
上寄せ
flex-end
data:image/s3,"s3://crabby-images/9836c/9836c391a1423de16634c4331cc27c3cb8bc36dd" alt=""
下寄せ
center
data:image/s3,"s3://crabby-images/8fa3f/8fa3f6e055ff52d15f4fd520cebaa93532959fd5" alt=""
中央寄せ
space-between
data:image/s3,"s3://crabby-images/e312f/e312f435fff2ffd5933640ad1c3ef3cdfa809653" alt=""
子要素の縦幅に均等の余白
space-around
data:image/s3,"s3://crabby-images/0bfca/0bfca87e4475bbc8b8d3bcc47528aa5d3bb79576" alt=""
均等の余白+端に半分の余白
See the Pen align-content: flex-start; by とりとん (@darakerutoriton) on CodePen.
See the Pen align-content: flex-end; by とりとん (@darakerutoriton) on CodePen.
See the Pen align-content: center; by とりとん (@darakerutoriton) on CodePen.
See the Pen align-content: space-between; by とりとん (@darakerutoriton) on CodePen.
See the Pen align-content: space-around; by とりとん (@darakerutoriton) on CodePen.
子要素:flexアイテムのプロパティ
子要素に記述することで、個別に位置を指定することができるプロパティをまとめてみました!
order:子要素の順番
flex-grow:子要素の伸び率
flex-shrink:子要素の縮み率
flex-growとflex-shrinkの計算方法はこちら⬇️
flex-basis:子要素の横幅
■ flex
子要素の伸縮比率と横幅は、まとめて記述することができます(例)⬇️
See the Pen flex_ by とりとん (@darakerutoriton) on CodePen.
align-self:子要素個別の縦位置
これはあまり使用する機会は無いかもですが、興味があれば!
flex-start
data:image/s3,"s3://crabby-images/f2853/f28539b456587e5e0269f9bb0b237433ee5c574c" alt=""
上寄せ
flex-end
data:image/s3,"s3://crabby-images/a88f4/a88f41bc8d3938218e3afeaab30871052beb599c" alt=""
下寄せ
center
data:image/s3,"s3://crabby-images/cc24e/cc24e0f14695d9b279927d1cc4c664f4f196653f" alt=""
中央寄せ
auto(初期値)
data:image/s3,"s3://crabby-images/ff799/ff799bd0270fabb82e6436e868b48d8dd29f794a" alt=""
親要素の縦幅に合わせる
stretch
data:image/s3,"s3://crabby-images/ff799/ff799bd0270fabb82e6436e868b48d8dd29f794a" alt=""
親要素の縦幅に合わせる
baseline
data:image/s3,"s3://crabby-images/75717/7571746b31486544b2fc912d0e1bd05815cb7c3e" alt=""
テキストの下線に揃える
See the Pen flex-start by とりとん (@darakerutoriton) on CodePen.
See the Pen flex-end by とりとん (@darakerutoriton) on CodePen.
See the Pen center by とりとん (@darakerutoriton) on CodePen.
See the Pen stretch by とりとん (@darakerutoriton) on CodePen.
See the Pen baseline by とりとん (@darakerutoriton) on CodePen.