“SuperFish” ドロップダウンメニュー

“SuperFish”は、既存の純粋なCSSドロップダウン・メニュー(JavaScriptを使わずに優雅に動作する)を強化するコバンザメスタイルのjQuery pluginでとても重宝されています。詳細はこちらhttp://users.tpg.com.au/j_birch/plugins/superfish

スクリプトタグのsrc属性にjQueryフレームワークとsuperfish.jsを指定する必要があります。

<script type="text/javascript" src="jquery-1.4.2.min.js"></script>
<script type="text/javascript" src="superfish.js"></script>

index-#.htmlには基本的な値を使用してスクリプト機能を初期化する以下のコードが含まれています。

<script type="text/javascript">
  $(document).ready(function() {
    $('ul.sf-menu').superfish({
      hoverClass: 'sfHover', // ホバーされたリスト項目に適用されるクラス
      pathClass: 'overideThisToUse', // 現在のページにつながるアイテムを一覧表示するために適用されている
      pathLevels: 1,  // 開くままか、pathClassを使用して回復されるサブメニューのレベルの数
      delay: 800,  // マウスがはずれた時にサブメニューが閉じずに外に残ることをミリ秒単位で遅らせる
      animation:  {opacity:'show'}, // jQuery’s .animate()メソッドの最初のパラメータ
      speed:  'normal', //jQuery’s .animate()メソッドの二番目のパラメータです。アニメーションのスピードを指定します
      autoArrows: true, // trueの時、初期設定からクリーナーソースコードで矢印を自動的に生成する
      dropShadows: true,  // falseに設定するとドロップシャドウを無効
      disableHI: false, // hoverIntent検出を無効にするにはtrueに設定する
      onInit: function(){}, // コールバック関数を1回起動するとSuperfishが初期化される – 'this'はulの内容を指します
      onBeforeShow: function(){},  // コールバック関数は、アニメーションが始まる前に起動する – 'this'は開く前のulを指します
      onShow: function(){}, // 一度アニメーションが完了したら関数が呼び出されます – 'this'は開かれたulです
      onHide: function(){} // サブメニューが閉じた後に関数が呼び出されます – 'this'は閉じたulを指します
    });
  });
</script> 

HTML

一般的なHTMLの記述例です:

<ul class="sf-menu">
  <li class="first"> <a class="current" href="index.html">Home</a>
    <ul>
      <li class="first"><a href="#">Free Mobile Website</a></li>
      <li><a href="#">Premium mobile templates</a></li>
      <li class="last"><a href="#">All devices templates</a></li>
    </ul>
  </li>
  <li><a href="#">templates</a></li>
  <li><a href="#">Demo</a></li>
  <li><a href="index-1.html">company</a></li>
  <li class="last"><a href="#">Contacts</a></li>
</ul>

CSS

/*** ESSENTIAL STYLES ***/
.sf-menu, .sf-menu * {
    margin:0;
    padding:0;
    list-style:none;
}
.sf-menu {
    line-height:1.0;
}
.sf-menu ul {
    position:
    absolute;
    top:-999em;
    width:10em; /* left offset of submenus need to match (see below) */
}
.sf-menu ul li {
    width:100%;
}
.sf-menu li:hover {
    visibility:
    inherit; /* fixes IE7 'sticky bug' */
}
.sf-menu li {
    float:left;
    position:relative;
}
.sf-menu a {
    display:block;
    position:relative;
}
.sf-menu li:hover ul,.sf-menu li.sfHover ul {
    left:0;
    top:2.5em; /* match top ul list item height */
    z-index:    99;
}
 
ul.sf-menu li:hover li ul,ul.sf-menu li.sfHover li ul {
    top:-999em;
}
ul.sf-menu li li:hover ul,ul.sf-menu li li.sfHover ul {
    left:10em; /* match ul width */
    top:0;
}
ul.sf-menu li li:hover li ul,ul.sf-menu li li.sfHover li ul {
    top:-999em;
}
ul.sf-menu li li li:hover ul,
ul.sf-menu li li li.sfHover ul {
    left:10em; /* match ul width */
    top:0;
}
/*** DEMO SKIN ***/
.sf-menu {
    float:left;
    margin-bottom:1em;
}
.sf-menu a {
    border-left:1px solid #fff;
    border-top:    1px solid #CFDEFF;
    padding:         .75em 1em;
    text-decoration:none;
}
.sf-menu a, .sf-menu a:visited  { /* visited pseudo selector so IE6 applies text colour*/
    color:#13a;
}
.sf-menu li {
    background:#BDD2FF;
}
.sf-menu li li {
    background:#AABDE6;
}
.sf-menu li li li {
    background:#9AAEDB;
}
.sf-menu li:hover, .sf-menu li.sfHover,
.sf-menu a:focus, .sf-menu a:hover, .sf-menu a:active {
    background:#CFDEFF;
    outline:0;
}
 
/*** arrows **/
.sf-menu a.sf-with-ul {
    padding-right:2.25em;
    min-width:1px; /* trigger IE7 hasLayout so spans position accurately */
}
.sf-sub-indicator {
    position:absolute;
    display:block;
    right:.75em;
    top:1.05em; /* IE6 only */
    width:10px;
    height:10px;
    text-indent:-999em;
    overflow:hidden;
    background:url('../images/arrows-ffffff.png') no-repeat -10px -100px; /* 8-bit indexed alpha png. IE6 gets solid image only */
}
a > .sf-sub-indicator {  /* give all except IE6 the correct values */
    top:.8em;
    background-position: 0 -100px; /* use translucent arrow for modern browsers*/
}
/* apply hovers to modern browsers */
a:focus > .sf-sub-indicator,
a:hover > .sf-sub-indicator,
a:active > .sf-sub-indicator,
li:hover > a > .sf-sub-indicator,
li.sfHover > a > .sf-sub-indicator {
    background-position: -10px -100px; /* arrow hovers for modern browsers*/
}
 
/* point right for anchors in subs */
.sf-menu ul .sf-sub-indicator { 
    background-position:  -10px 0; 
}
.sf-menu ul a > .sf-sub-indicator { 
    background-position:  0 0; 
}
/* apply hovers to modern browsers */
.sf-menu ul a:focus > .sf-sub-indicator,
.sf-menu ul a:hover > .sf-sub-indicator,
.sf-menu ul a:active > .sf-sub-indicator,
.sf-menu ul li:hover > a > .sf-sub-indicator,
.sf-menu ul li.sfHover > a > .sf-sub-indicator {
    background-position: -10px 0; /* arrow hovers for modern browsers*/
}
 
/*** shadows for all but IE6 ***/
.sf-shadow ul {
    background:url('../images/shadow.png') no-repeat bottom right;
    padding: 0 8px 9px 0;
    -moz-border-radius-bottomleft: 17px;
    -moz-border-radius-topright: 17px;
    -webkit-border-top-right-radius: 17px;
    -webkit-border-bottom-left-radius: 17px;
}
.sf-shadow ul.sf-shadow-off {
    background: transparent;
}

Comments are closed.