superfish.js 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. /****************************************************************
  2. * *
  3. * 代码库 *
  4. * www.dmaku.com *
  5. * 努力创建完善、持续更新插件以及模板 *
  6. * *
  7. ****************************************************************/
  8. /*
  9. * Superfish v1.4.8 - jQuery menu widget
  10. * Copyright (c) 2008 Joel Birch
  11. *
  12. * Dual licensed under the MIT and GPL licenses:
  13. * http://www.opensource.org/licenses/mit-license.php
  14. * http://www.gnu.org/licenses/gpl.html
  15. * http://www.yaoyingying.com/css/jquery/superfish/#getting-started [china]
  16. *
  17. * CHANGELOG: http://users.tpg.com.au/j_birch/plugins/superfish/changelog.txt
  18. */
  19. ;(function($){
  20. $.fn.superfish = function(op){
  21. var sf = $.fn.superfish,
  22. c = sf.c,
  23. $arrow = $(['<span class="',c.arrowClass,'"> &#187;</span>'].join('')),
  24. over = function(){
  25. var $$ = $(this), menu = getMenu($$);
  26. clearTimeout(menu.sfTimer);
  27. $$.showSuperfishUl().siblings().hideSuperfishUl();
  28. },
  29. out = function(){
  30. var $$ = $(this), menu = getMenu($$), o = sf.op;
  31. clearTimeout(menu.sfTimer);
  32. menu.sfTimer=setTimeout(function(){
  33. o.retainPath=($.inArray($$[0],o.$path)>-1);
  34. $$.hideSuperfishUl();
  35. if (o.$path.length && $$.parents(['li.',o.hoverClass].join('')).length<1){over.call(o.$path);}
  36. },o.delay);
  37. },
  38. getMenu = function($menu){
  39. var menu = $menu.parents(['ul.',c.menuClass,':first'].join(''))[0];
  40. sf.op = sf.o[menu.serial];
  41. return menu;
  42. },
  43. addArrow = function($a){ $a.addClass(c.anchorClass).append($arrow.clone()); };
  44. return this.each(function() {
  45. var s = this.serial = sf.o.length;
  46. var o = $.extend({},sf.defaults,op);
  47. o.$path = $('li.'+o.pathClass,this).slice(0,o.pathLevels).each(function(){
  48. $(this).addClass([o.hoverClass,c.bcClass].join(' '))
  49. .filter('li:has(ul)').removeClass(o.pathClass);
  50. });
  51. sf.o[s] = sf.op = o;
  52. $('li:has(ul)',this)[($.fn.hoverIntent && !o.disableHI) ? 'hoverIntent' : 'hover'](over,out).each(function() {
  53. if (o.autoArrows) addArrow( $('>a:first-child',this) );
  54. })
  55. .not('.'+c.bcClass)
  56. .hideSuperfishUl();
  57. var $a = $('a',this);
  58. $a.each(function(i){
  59. var $li = $a.eq(i).parents('li');
  60. $a.eq(i).focus(function(){over.call($li);}).blur(function(){out.call($li);});
  61. });
  62. o.onInit.call(this);
  63. }).each(function() {
  64. var menuClasses = [c.menuClass];
  65. if (sf.op.dropShadows && !($.browser.msie && $.browser.version < 7)) menuClasses.push(c.shadowClass);
  66. $(this).addClass(menuClasses.join(' '));
  67. });
  68. };
  69. var sf = $.fn.superfish;
  70. sf.o = [];
  71. sf.op = {};
  72. sf.IE7fix = function(){
  73. var o = sf.op;
  74. if ($.browser.msie && $.browser.version > 6 && o.dropShadows && o.animation.opacity!=undefined)
  75. this.toggleClass(sf.c.shadowClass+'-off');
  76. };
  77. sf.c = {
  78. bcClass : 'sf-breadcrumb',
  79. menuClass : 'sf-js-enabled',
  80. anchorClass : 'sf-with-ul',
  81. arrowClass : 'sf-sub-indicator',
  82. shadowClass : 'sf-shadow'
  83. };
  84. sf.defaults = {
  85. hoverClass : 'sfHover',
  86. pathClass : 'overideThisToUse',
  87. pathLevels : 1,
  88. delay : 350,
  89. animation : {opacity:'show'},
  90. speed : 'normal',
  91. autoArrows : true,
  92. dropShadows : true,
  93. disableHI : false, // true disables hoverIntent detection
  94. onInit : function(){}, // callback functions
  95. onBeforeShow: function(){},
  96. onShow : function(){},
  97. onHide : function(){}
  98. };
  99. $.fn.extend({
  100. hideSuperfishUl : function(){
  101. var o = sf.op,
  102. not = (o.retainPath===true) ? o.$path : '';
  103. o.retainPath = false;
  104. var $ul = $(['li.',o.hoverClass].join(''),this).add(this).not(not).removeClass(o.hoverClass)
  105. .find('>ul').hide().css('visibility','hidden');
  106. o.onHide.call($ul);
  107. return this;
  108. },
  109. showSuperfishUl : function(){
  110. var o = sf.op,
  111. sh = sf.c.shadowClass+'-off',
  112. $ul = this.addClass(o.hoverClass)
  113. .find('>ul:hidden').css('visibility','visible');
  114. sf.IE7fix.call($ul);
  115. o.onBeforeShow.call($ul);
  116. $ul.animate(o.animation,o.speed,function(){ sf.IE7fix.call($ul); o.onShow.call($ul); });
  117. return this;
  118. }
  119. });
  120. })(jQuery);