アイコンWeb制作実験

HTML/CSS/jQuery/Fabric.js
を試した様子と結果です.

CSSのfloatで段組レイアウト - 3段組、バー固定幅、中央・右・左順

イメージ

公開:2015-10-14

更新:

CSSのfloatで段組みレイアウト22種のうちの1つ:3段組み、バー固定幅、中央・右・左順です。ウィンドウ幅で並びが縦横変わるレスポンシブ、コンテンツ部可変幅のリキッドデザインです。

無料フリー、著作権表や登録なし、コピペOKです。

概要

CSSで3段組 縦並び CSSで3段組 横並び

スマホなど小さい幅では上からB1→B2→B3と縦並びします。

PCなど大きい幅では図の順で横並びします。左右サイドバーはCSSで設定した幅を保ち、中央は幅が変化します。

コードと解説

<div id="boxA">
  <p>A</p>
</div>
<div id="wrap1">
  <div id="wrap2">
    <div id="boxB1">
      <p>B1</p>
    </div>
    <div id="boxB2">
      <p>B2</p>
    </div>
  </div>
  <div id="boxB3">
    <p>B3</p>
  </div>
</div>
<div id="boxC">
  <p>C</p>
</div>
#wrap1	{
  width: 90%;
  margin: auto;
}

#wrap1::after	{
  content: "";
  display: block;
  clear: both;
}

#boxA	{
  border: 10px solid #f99; /* red */
}

#boxB1	{
  border: 10px solid #99f; /* purple */
}

#boxB2	{
  border: 10px solid #9cf; /* blue */
  background-color: #fff;
}

#boxB3	{
  border: 10px solid #9cf; /* blue */
}

#boxC	{
  border: 10px solid #6f9; /* green */
}

@media screen and (min-width:641px){
#wrap2	{
  box-sizing: border-box;
  float: right;
  margin-left: -150px;
  padding-left: 150px;
  width: 100%;
}

#boxB1	{
  box-sizing: border-box;
  float: left;
  margin-right: -200px;
  padding-right: 200px;
  width: 100%;
}

#boxB2	{
  box-sizing: border-box;
  float: right;
  width: 200px;
}

#boxB3	{
  box-sizing: border-box;
  float: left;
  width: 150px;
}
}

行と説明

2
中段boxB群の幅を狭める割合です。狭めずboxA/Cと同幅にする場合は100%、または1~4行を削除してください。
12~31
範囲と動作をわかりやすく枠を表示させているだけですので任意に削除してください。
22
B1に背景やボーダーを用いる場合はB2に重なるためB2の背景を白としています。任意の色などに変えてください。B1に背景やボーダーを用いない場合は不要です。
33
ブレイクポイント(縦並びと横並びの境目)で、641px以上で横並びとしています。任意に変えてください。
37,38,59
左サイドバーの幅です。任意に変えてください。
45,46,53
右サイドバーの幅です。任意に変えてください。

広がりすぎ防止

更にCSSで、body#wrap1のどちらかに以下の最大幅指定をして横長になりすぎを防ぎます。値は任意に変えてください。

	max-width: 960px;
  • bodyに入れた場合はboxA/Cも広がりが止まります。
  • #wrap1に入れた場合はboxA/Cは広がり続け、中段のboxB群のみ広がりが止まります。

ご利用方法

コード記述枠内(どこでも可)をダブルクリックすると黒く反転しますので、コピー&ペーストしてお使いください。

著作権について詳しくは免責事項 - 著作権を参照願います。

その他の段組みパターン

上記のHTMLと全く同じ、またはほとんど同じで、CSSを変えることによって別のレイアウトもできます。それはこちら。

CSSのfloatでの段組みレイアウト22種(2段/3段、サイド固定幅/可変幅)