Movable Type 備忘録

 

 サイドバーを折りたたむ

わたしのブログは人気がないのでコメントとか、トラックバックが少ないから問題ないのですが、みなさんのブログには必要なはず!!
そう、サイドバーに最近のエントリ最近のトラックバックなどを一覧表示していると、少ないうちはいいのですが、数が多くなると煩わしくなりませんか!?

今さらですが、必要なときだけ一覧表示可能な、サイドバーの折りたたみについてTRYしてみようと思います。

今回参考にさせていただいたサイトはダイズバタケ様です。

カスタマイズ方法

サイドバーの折りたたみには、JavaScriptを使用します。
以下のコードはクリックのたびにリストを表示したり、たたんだりするJavaScriptです。

function toggleFold(sender, id) {
  var elm = document.getElementById(id);
  if (elm.style.display == "none") {
    elm.style.display = "block";
    sender.className = "unfolded";
  } else {
    elm.style.display = "none";
    sender.className = "folded";
  }
}

上記コードをファイルに保存します。
保存ファイル名は任意ですが、例えば folding_sidebar.js という名前で保存します。

保存したJavaScriptをアップロードします。
先ほどの folding_sidebar.js というファイルをサーバーにアップロードします。

アップロードする場所はどこでも構いません。各自の環境に合わせてアップロードしてください。
index.html と同じディレクトリなんかいいかも、です。

サイドバー折りたたみのコードを埋め込みます。
以下のコードを、折りたたみたいところと差し替えてください。

<script type="text/javascript" src="folding_sidebar.js"></script>
<h3 class="unfolded" onmousedown="toggleFold(this, 'sidebar_menu');">最近のコメント</h3>
<div id="sidebar_menu" style="display: block;">
 例えば、コメント一覧など…
</div>

上記コードは、デフォルトでは開いておきたい場合のコードになります。
以下は、デフォルトでたたんでおきたい場合のコードです。

<script type="text/javascript" src="folding_sidebar.js"></script>
<h3 class="folded" onmousedown="toggleFold(this, 'sidebar_menu');">最近の記事</h3>
<div id="sidebar_menu" style="display: none;">
 例えば、記事一覧など…<br />
</div>

いずれも、青い字の部分の名前を合わせるところがポイントです。
また、複数のサイドバー折りたたみを行う場合には、それぞれ別々な名前をつけます。

例えば、カテゴリ一覧なら category_menu とし、コメント一覧なら comment_menu などとします。

スタイルシートを変更します。
スタイルシートに以下のスタイルを追加します。

/*開くマーク*/
.folded {
  background-image: url(./image/folded.gif);
  background-repeat: no-repeat;
  background-position: 5px center;
}
/*閉じるマーク*/
.unfolded {
  background-image: url(./image/unfolded.gif);
  background-repeat: no-repeat;
  background-position: 5px center;
}

青い時の部分を、各自の環境に合わせて変更します。
イメージファイルは、 でよければお持ちください。
置き換えが完了したら、いつものように保存して再構築してください。

以上で、サイドバーの折りたたみができました。

 Trackback Pings(0)

No trackbacks found.

 Comments(0)

No comments found.

 Post a Comment

コメント用フィード