Bootstrapをカスタマイズ!ページをスマホで表示した際に横からナビゲーションをスライドさせる -Bootstrap Offcanvas
Post on:2015年3月6日
Bootstrapで実装したページをスマホなどの幅が狭いスクリーンで表示した際に、横からオフキャンバスのナビゲーションをアニメーションでスライド表示させるJSとCSSのパックを紹介します。
data:image/s3,"s3://crabby-images/b243a/b243a65b83ebeebbd0e20a909a8ca98b1236d122" alt="サイトのキャプチャ"
Bootstrap Offcanvasのデモ
data:image/s3,"s3://crabby-images/d7641/d76416c6ee95a0278f7002533e8d48a5a4b94f37" alt="デモのキャプチャ"
スマホなどの表示サイズの幅が狭いスクリーンで表示した際には、右上にアイコンが表示され、それをタップするとナビゲーションが横からアニメーションでスライドします。
data:image/s3,"s3://crabby-images/b33c3/b33c3ce0e109c5b64e00ca14c09248a11396240d" alt="デモのアニメーション"
デモのアニメーション
ちなみに、Bootstrapの標準のオフキャンバスはこんな感じです。
data:image/s3,"s3://crabby-images/d1d10/d1d10d11db75c2a136bc6a5cfcba8914769b9d28" alt="デモのアニメーション"
Bootstrap Offcanvasの使い方
Step 1: 外部ファイル
当スタイルシートとスクリプトを外部ファイルとして記述します。
<head> ... <link rel="stylesheet" href="../dist/css/bootstrap.offcanvas.min.css"/> </head> <body> ... <script src="../dist/js/bootstrap.offcanvas.js"></script> </body>
Step 2: HTML
まずは、オフキャンバスのナビゲーションを開くボタン。
<button type="button" class="navbar-toggle offcanvas-toggle" data-toggle="offcanvas" data-target="#js-bootstrap-offcanvas"> <span class="sr-only">Toggle navigation</span> <span class="icon-bar"></span> <span class="icon-bar"></span> <span class="icon-bar"></span> </button>
ナビゲーションは、nav要素で配置します。
<nav class="navbar navbar-default navbar-offcanvas" role="navigation" id="js-bootstrap-offcanvas"> ... </nav>
Step 3: カスタマイズ
ナビゲーションのカスタマイズは、スタイルシートで簡単にできます。
$offcanvas-width: 250px !default; // ナビゲーションの幅 $offcanvas-animation-time: 0.15s !default; // エフェクトの時間 $offcanvas-toggle-background: #f8f8f8 !default; // トグルの背景のカラー $offcanvas-toggle-bars-color: #000 !default; // トグルのアイコンバーのカラー
sponsors