menu
menu

キーワード検索

 

最近の投稿

CSSだけでサイズ可変・スマホ対応のアコーディオン

  • Labs

CSS3

こんにちは(・∀・)

CSS3のAnimationやtransitionといったプロパティのおかげでJavaScriptを使わなくても動きのあるWebサイトが作れるようになってきました。そこで今回はCSSだけで作る、サイズが可変してスマホにも対応したアコーディオンをご紹介します。

スマホ対応のアコーディオン

チェックボックスを使ったアコーディオンとラジオボタンを使ったアコーディオンの2種類です。それぞれの特質にあわせた形でアコーディオンが展開されます。チェックボックスを使ったアコーディオンはその性質上、ボタンを選択(クリック)したら選択した分すべて展開しますが、ラジオボタンのアコーディオンはnameでグループになっているので選択(クリック)した分だけ展開します。また、最初から展開している状態で表示したい場合はinput要素にcheckedを入れればページを開いた時点でその要素は開いて表示されます。

サンプルは横幅100%で可変になっています。min-widthを300pxに設定してありますので、そのサイズまでブラウザ幅を縮めると横スクロールバーが出ます。

チェックボックスやラジオボタンがトリガーとなり展開する仕組みですのでアコーディオンだけではなく、ツリーメニューやタブレイアウトでも使えそうですね。

IEは9以上で正しく動作します。

1. チェックボックスでアコーディオン
サンプル
HTML

<div class="accordion">
<div class="ac-content">
<label for="ac-cap1">1</label>
<input id="ac-cap1" type="checkbox">
<div class="ac-cont">
<p>コンテンツ1</p>
</div>
<label for="ac-cap2">2</label>
<input id="ac-cap2" type="checkbox">
<div class="ac-cont">
<p>コンテンツ2</p>
</div>
<label for="ac-cap3">3</label>
<input id="ac-cap3" type="checkbox">
<div class="ac-cont">
<p>コンテンツ3</p>
</div>
<label for="ac-cap4">4</label>
<input id="ac-cap4" type="checkbox">
<div class="ac-cont">
<p>コンテンツ4</p>
</div>
<label for="ac-cap5">5</label>
<input id="ac-cap5" type="checkbox">
<div class="ac-cont">
<p>コンテンツ5</p>
</div>
<!--ac-content--></div>
<!--accordion--></div>

以下のコードをHTMLに記述すればレイアウトは崩れますがIE8でもコンテンツを表示することができます。


<!--[if lt IE 9]>
<style>
.accordion .ac-cont {/*1番のサンプル用*/
  height: auto;
}
</style>
<![endif]-->
CSS

.accordion {
  min-width: 300px;
  margin: 0 auto;
  padding: 10px;
}
.accordion .ac-content {
  margin: 0 10px;
}
.accordion input {
  display: none;
}
.accordion label {
  display: block;
  background: #9fb7d4;
  cursor: pointer;
  padding: 10px;
  border-bottom: 1px solid #fff;
}
.accordion label:hover {
  background: #ccc;
}
.accordion .ac-cont {
  transition: 0.2s;
  height: 0;
  overflow: hidden;
  background: #ddd;
  padding: 0 10px;
}
.accordion input:checked + .ac-cont {
  height: auto;
  padding: 10px;
}
Result

サンプルデモはこちら

2. ラジオボタンでアコーディオン
サンプル
HTML

<div class="accordion2">
<div class="ac-content">
<label for="ac2-cap1">1</label>
<input id="ac2-cap1" type="radio" name="ac2" checked>
<div class="ac2-cont">
<p>コンテンツ1</p>
</div>
<label for="ac2-cap2">2</label>
<input id="ac2-cap2" type="radio" name="ac2">
<div class="ac2-cont">
<p>コンテンツ2</p>
</div>
<label for="ac2-cap3">3</label>
<input id="ac2-cap3" type="radio" name="ac2">
<div class="ac2-cont">
<p>コンテンツ3</p>
</div>
<label for="ac2-cap4">4</label>
<input id="ac2-cap4" type="radio" name="ac2">
<div class="ac2-cont">
<p>コンテンツ4</p>
</div>
<label for="ac2-cap5">5</label>
<input id="ac2-cap5" type="radio" name="ac2">
<div class="ac2-cont">
<p>コンテンツ5</p>
</div>
<!--ac-content--></div>
<!--accordion2--></div>

以下のコードをHTMLに記述すればレイアウトは崩れますがIE8でもコンテンツを表示することができます。


<!--[if lt IE 9]>
<style>
.accordion2 .ac2-cont {/*2番のサンプル用*/
  height: auto;
}
</style>
<![endif]-->
CSS

.accordion2 {
  min-width: 300px;
  margin: 0 auto;
  padding: 10px;
}
.accordion2 .ac-content {
  margin: 0 10px;
}
.accordion2 label {
  display: block;
  background: #9fb7d4;
  cursor: pointer;
  padding: 10px;
  border-bottom: 1px solid #fff;
}
.accordion2 label:hover {
  background: #ccc;
}
.accordion2 input {
  display: none;
}
.accordion2 .ac2-cont {
  transition: 0.2s;
  height: 0;
  overflow: hidden;
  background: #ddd;
  padding: 0 10px;
}
.accordion2 input:checked + .ac2-cont {
  height: auto;
  padding: 10px;
}
Result

サンプルデモはこちら

関連リンク

CSSだけで横に展開するアコーディオン
横方向に展開するアコーディオン
サイズ可変・スマホ対応のアコーディオン

参考

かつてはJavaScriptを利用していたものの、今ではCSSのみで実装できる10の小技
CSSだけでメニューが開いたり閉じたりするアコーディオンを作る!javascript不要

  • カテゴリー:Labs