CSS「Flex」(Flex)ボックス
📍 Flexboxとは?
CSSのflexは、要素のサイズや位置を簡単に特定できるツールです.箱と物品は行や列を通じて自由に置くことができる機能です. flexboxの前にtable、position、floatが使用されていました.
▼floatの本来の目的は、画像やテキストをどのように配置するかを定義することだったが、htmlではレイアウトの面で劣勢だったため、floatを使うには多くの用途があり、結果的に本来の目的から逸脱し、flex boxが現れた後、floatは元の目的で使用できるようになった. 1.Flexboxの特性
FlexBoxを使用するには2段階のタグが必要です.コンテナとしての親ラベル 物品のサブタブ
コンテナに入る属性値とエントリの属性値に分けられます.
中心軸と反対軸があります.の中心軸を垂直または水平に維持すると、別の軸が変更されます.
ex.)項目が上から下、すなわち垂直に位置合わせされている場合、中心軸は垂直で、もう一方の軸は水平である.
2. Flex Container
flex-direction
:flexboxの主軸を決定します.プロジェクトの方向を決定します.
flex-wrap
:1行の項目がいっぱいになった場合、その行をスキップするかどうかを決定します.
: (flex-direction + flex-wrap) shorthand
justify-content
:中心軸でソートします.空白を残したい時に使います.
align-items
:itemを写真の反対の軸で並べ替えます.
align-content
:itemを写真の反対の軸で並べ替えます.
ξnowrap(線が1本形成されている)であれば、使用する意味はありません. 3. Flex Items
order
:アイテムの順序を変更します.
flex-grow
:コンテナが大きくなると、各アイテムがどのような割合で大きくなるかを決定します.
単位(px、emなど)のない値(数値のみ)を指定します.これはパーセントを意味します.負数は使用できません.
:コンテナが小さくなると、各アイテムがどの割合で縮小されるかを決定します.
負数は使用できません.
:コンテナのサイズが変化する前に、基本状態でのサイズを決定します.
物がどれだけのスペースを占めるかをもっと詳しく説明します.(それぞれ60%、30%、10%などを占めるかどうかを指定できます.)
: (flex-grow + flex-shrink + flex-basis) shorthandデフォルト: 第2の ▼▼▼▼属性を個別に設定するよりも、2479142行短くしたほうがいい!
align-self
:アイテムごとにソートできます.△容器に指定されたものを除き、1つのものしか指定できません.
reference
flexbox Coding-Everybody
CSSのflexは、要素のサイズや位置を簡単に特定できるツールです.
▼floatの本来の目的は、画像やテキストをどのように配置するかを定義することだったが、htmlではレイアウトの面で劣勢だったため、floatを使うには多くの用途があり、結果的に本来の目的から逸脱し、flex boxが現れた後、floatは元の目的で使用できるようになった.
FlexBoxを使用するには2段階のタグが必要です.
data:image/s3,"s3://crabby-images/049a5/049a508275e3fdabf24a2ce5289b4cf545cd6912" alt=""
data:image/s3,"s3://crabby-images/dc622/dc6226bac97dbfa5298a5773bb3fd097b17dc4b9" alt=""
中心軸と反対軸があります.
ex.)項目が上から下、すなわち垂直に位置合わせされている場合、中心軸は垂直で、もう一方の軸は水平である.
data:image/s3,"s3://crabby-images/4d0f6/4d0f6ce5520d0b5a7222dd0745dcea4ee4b18f89" alt=""
data:image/s3,"s3://crabby-images/eb101/eb1011b5dad34bc53520ba1fcbcbccc8b8a652c4" alt=""
data:image/s3,"s3://crabby-images/da77e/da77e0bc4a71adc10c89048cf5870282ce9dbb19" alt=""
flex-direction
:flexboxの主軸を決定します.プロジェクトの方向を決定します.
flex-direction: row;
(デフォルト):水平方向に整列します.(left → right)flex-direction: row-reverse;
:水平方向の逆ソート.(right → left)flex-direction: column;
:垂直方向に整列します.(top → bottom)flex-direction: column-reverse;
:垂直方向に反対します.(bottom → top) .container {
flex-direction: row | row-reverse | column | column-reverse;
}
data:image/s3,"s3://crabby-images/84971/849711734b4602b2bbd7ea779cbbea53da0ea1fc" alt=""
flex-wrap
:1行の項目がいっぱいになった場合、その行をスキップするかどうかを決定します.
flex-wrap: nowrap;
(デフォルト):すべてのアイテムが1行に並んでいます.flex-wrap: wrap;
:プロジェクトは複数の線上に分布します.(top → bottom)flex-wrap: wrap-reverse;
:プロジェクトは複数の線で、下から上へ並べられています.(bottom → top).container {
flex-wrap: nowrap | wrap | wrap-reverse;
}
📌 flex-flow: (flex-direction + flex-wrap) shorthand
.container { flex-flow: column wrap; }
data:image/s3,"s3://crabby-images/6826d/6826dc31a4cb010037456d917841ddf2d0c93ce8" alt=""
justify-content
:中心軸でソートします.空白を残したい時に使います.
justify-content: flex-start;
(デフォルト):itemを開始点に集約します.justify-content: flex-end;
:プロジェクトをエンドポイントに集合します.justify-content: center;
:プロジェクトを回線の中央に集中します.justify-content: space-between;
:最初の項目は始点で、最後の項目は終点で、スペースは均等に分けられます.justify-content: space-around;
:各項目の両側に同じサイズの空白があります.余白は各項目間の余白より小さい.justify-content: space-evenly;
:各項目の間とエッジの空白は同じです..container {
justify-content: flex-start | flex-end | center | space-between | space-around | space-evenly | start | end | left | right ... + safe | unsafe;
}
data:image/s3,"s3://crabby-images/b46ef/b46ef3e2e961f30602940d944ff73e1996415297" alt=""
align-items
:itemを写真の反対の軸で並べ替えます.
align-items: stretch;
(デフォルト):すべてのコンテナを追加します.(min-width/max-width値は変わらない.)align-items: center;
:プロジェクトを回線の中央に集中します.align-items: baseline;
:itemベースライン順.container {
align-items: stretch | flex-start | flex-end | center | baseline | first baseline | last baseline | start | end | self-start | self-end + ... safe | unsafe;
}
data:image/s3,"s3://crabby-images/277ea/277ea7c8ff868a830035af0ef5640ee6344566ef" alt=""
align-content
:itemを写真の反対の軸で並べ替えます.
flex line
に並べられています.ξnowrap(線が1本形成されている)であれば、使用する意味はありません.
.container {
align-content: flex-start | flex-end | center | space-between | space-around | space-evenly | stretch | start | end | baseline | first baseline | last baseline + ... safe | unsafe;
}
▼▼alin-content&align-items区分!align-content
:flex lineをソートします.nowrapであれば、使う意味がありません.nowrapは強制的に1行に描画されるのでflex lineは1行です.align-items
:flex lineを基準にアイテムをソートします.align-itmesは、1行の場合もその行内でソートされるため、動作します.data:image/s3,"s3://crabby-images/d5610/d561052b167c0f191b67b70423a424a9df263931" alt=""
data:image/s3,"s3://crabby-images/6104b/6104b8c75bc4df3ab54d449c354ce84c2f313cb5" alt=""
order
:アイテムの順序を変更します.
.item {
order: 5; /* default is 0 */
}
data:image/s3,"s3://crabby-images/31f3a/31f3a935c43ab8e87acc0ef8eb05e48da9be5d1b" alt=""
flex-grow
:コンテナが大きくなると、各アイテムがどのような割合で大きくなるかを決定します.
単位(px、emなど)のない値(数値のみ)を指定します.これはパーセントを意味します.負数は使用できません.
.item {
flex-grow: 4; /* 기본값: 0 */
}
flex-shrink:コンテナが小さくなると、各アイテムがどの割合で縮小されるかを決定します.
負数は使用できません.
.item {
flex-shrink: 3; /* 기본값: 1 */
}
flex-basis:コンテナのサイズが変化する前に、基本状態でのサイズを決定します.
物がどれだけのスペースを占めるかをもっと詳しく説明します.(それぞれ60%、30%、10%などを占めるかどうかを指定できます.)
.item {
flex-basis: | auto; /* 기본값: auto */
}
📌 flex: (flex-grow + flex-shrink + flex-basis) shorthand
.item { flex: none | [ <'flex-grow'> <'flex-shrink'>? || <'flex-basis'> ] }
0 1 auto
flex-shrink
、第3のflex-basis
パラメータは必須ではありません.data:image/s3,"s3://crabby-images/3bc6b/3bc6b6b15df0db786c8c61d7cf7613b1d290ccc6" alt=""
align-self
:アイテムごとにソートできます.△容器に指定されたものを除き、1つのものしか指定できません.
.item {
align-self: auto | flex-start | flex-end | center | baseline | stretch;
}
▶ playgroundを直接設定して確認できます.😀 reference
flexbox Coding-Everybody
Reference
この問題について(CSS「Flex」(Flex)ボックス), 我々は、より多くの情報をここで見つけました https://velog.io/@seul06/CSS-Flexテキストは自由に共有またはコピーできます。ただし、このドキュメントのURLは参考URLとして残しておいてください。
Collection and Share based on the CC Protocol