menu
menu

キーワード検索

 

最近の投稿

【制作Tips】jQueryで横方向に展開するアコーディオン

  • Labs

jQuery

こんにちは(・∀・)

今回も前回に引き続きアコーディオンのご紹介です。前回ご紹介したアコーディオンは縦バージョンでしたが今回は横バージョンです。

サンプル

アニメーションで動くタイプと普通にCSSで制御する2タイプです。サンプルはCSSで制御する設定になっています。アニメーションの制御に変える場合はJSを書き換えてご利用ください。

HTML

Google Hosted LibrariesからjQuery 1.x snippetを<head>内に読み込みます。


<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.0/jquery.min.js"></script>

<dl class="accordion">
<dt>1</dt>
<dd><div>コンテント</div></dd>
<dt>2</dt>
<dd><div>コンテント</div></dd>
<dt>3</dt>
<dd><div>コンテント</div></dd>
<dt>4</dt>
<dd><div>コンテント</div></dd>
<dt>5</dt>
<dd><div>コンテント</div></dd>
<!--accordion--></dl>
CSS

.accordion {
  width: 600px;
  height: 300px;
  margin: 0 auto;
  overflow: hidden;
  padding: 10px;
}
.accordion dt {
  float: left;
  width: 20px;
  height: 300px;
  background: #9fb7d4;
  cursor: pointer;
  padding: 10px;
  border-right: 1px solid #fff;
}
.accordion dd {
  float: left;
  width: 374px;
  height: 300px;
  display: none;
  padding: 10px;
  background: #ddd;
  border-right: 1px solid #fff;
}
.accordion dd div {
  width: 374px;
  height: 300px;
  overflow: hidden;
  padding: 10px;
  display: block;
}
JavaScript

/*アニメーションで制御の場合はこちらのスクリプト*/
$(function(){
$('.accordion dd').eq(0).show();
$('.accordion dt').click(function() {
$('.accordion dd').animate({width:'hide'},500);
$(this).next().animate({width:'toggle'},500);
});
});
/*CSSで制御の場合はこちらのスクリプト*/
$(function(){
$('.accordion dd').eq(0).show();
$('.accordion dt').click(function() {
$('.accordion dd').css('display','none');
$(this).next().css('display','block');
});
});
Result

サンプルデモはこちら


関連リンク

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

  • カテゴリー:Labs