2010-01-05 37 views
0

我遇到jQuery Lavalamp plugin问题。它可以与单级菜单完美配合,但是在添加下拉菜单后,它会有点丢失。这就是我的意思:http://screenr.com/0fS让Lavalamp jQuery插件与下拉菜单一起使用?

当然,我希望实现的是,当用户将鼠标悬停在子项上时,lavalamp背景将保留在Portfolio项目上。

我想这是一个稍微改变插件的问题,所以这里是插件的完整代码。所需要的只是一个简单的方法,使当前阶段的lavalamp停止,当<li>的孩子被徘徊,然后恢复正常工作后。以下是完整的插件代码供参考!

(function($) { 
$.fn.lavaLamp = function(o) { 
o = $.extend({ fx: "linear", speed: 500, click: function(){} }, o || {}); 

return this.each(function() { 
    var me = $(this), noop = function(){}, 
     $back = $('<li class="back"><div class="left"></div></li>').appendTo(me), 
     $li = $("li", this), curr = $("li.current", this)[0] || $($li[0]).addClass("current")[0]; 

    $li.not(".back").hover(function() { 
     move(this); 
    }, noop); 

    $(this).hover(noop, function() { 
     move(curr); 
    }); 

    $li.click(function(e) { 
     setCurr(this); 
     return o.click.apply(this, [e, this]); 
    }); 

    setCurr(curr); 

    function setCurr(el) { 
     $back.css({ "left": el.offsetLeft+"px", "width": el.offsetWidth+"px" }); 
     curr = el; 
    }; 

    function move(el) { 
     $back.each(function() { 
      $(this).dequeue(); } 
     ).animate({ 
      width: el.offsetWidth, 
      left: el.offsetLeft 
     }, o.speed, o.fx); 
    }; 

}); 
}; 
})(jQuery);` 

在此先感谢。

回答

0

我增加了额外的类顶级Li和更新的JS:

$li = $("li.top-level-item", this),