Flexboxで枠の幅をコンテンツの幅に合わせたサイズにする
Flexboxで枠の幅をコンテンツの幅に合わせたサイズにするコードを紹介します。
概要
Flexboxで枠の幅をコンテンツの幅に合わせたサイズにする場合には、
flex:0;
を指定します。
書式
実装例
コード
以下のHTML、CSSファイルを作成します。
.container {
display: flex;
border: 1px solid #ff6a00;
}
.frame1{
flex:1;
border: 1px solid #00b117;
margin: 0.5rem 0.5rem 0.5rem 0.5rem;
}
.frame2 {
flex: 2;
border: 1px solid #009c9c;
margin: 0.5rem 0.5rem 0.5rem 0.5rem;
}
.frame3 {
flex: 0;
border: 1px solid #7cae00;
margin: 0.5rem 0.5rem 0.5rem 0.5rem;
}
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title></title>
<link rel="stylesheet" href="flex-0.css" />
</head>
<body>
<div class="container">
<div class="frame1">
<p>枠1です</p>
<p>
ABCDE<br />
12345<br />
</p>
</div>
<div class="frame2">
<p>枠2です</p>
<p>
ABCDE<br />
12345<br />
</p>
</div>
<div class="frame3">
<p>枠3です</p>
<p>
ABCDE<br />
12345<br />
</p>
</div>
</div>
</body>
</html>
解説
frame1, frame2 クラスは flex プロパティの値が設定されているため、frame1の幅とframe2の幅が1:2となる比率で設定されます。
.frame1{
flex:1;
border: 1px solid #00b117;
margin: 0.5rem 0.5rem 0.5rem 0.5rem;
}
.frame2 {
flex: 2;
border: 1px solid #009c9c;
margin: 0.5rem 0.5rem 0.5rem 0.5rem;
}
frame3 は flexプロパティの値が0の設定のため、枠の幅にはコンテンツに合わせた幅(ワードラップありの最小の幅)になります。
.frame3 {
flex: 0;
border: 1px solid #7cae00;
margin: 0.5rem 0.5rem 0.5rem 0.5rem;
}
表示結果
上記のHTMLファイルをWebブラウザで表示します。下図のページが表示されます。「枠1」「枠2」の幅が1:2の表示で、一番右側の「枠3」がコンテンツの幅で表示されていることが確認できます。
幅を広げた場合の表示です。幅を広げても「枠3」はコンテンツの最小幅の状態になっています。
著者
iPentecのメインデザイナー
Webページ、Webクリエイティブのデザインを担当。PhotoshopやIllustratorの作業もする。