Obtenir le plugin Lavalamp jQuery pour travailler avec menu déroulant?
-
18-09-2019 - |
Question
J'ai un problème avec le plugin jQuery Lavalamp . Il fonctionne parfaitement avec un menu à un seul niveau, mais après avoir ajouté un menu déroulant, il devient un peu perdu. Voici ce que je veux dire. http://screenr.com/0fS
Bien sûr, ce que je voudrais obtenir est pour l'arrière-plan lavalamp de rester sur l'élément de portefeuille lorsque l'utilisateur passe au-dessus des sous-éléments.
Je suppose que c'est une question de changer le plug-in un peu, alors voici le code complet du plug-in. Ce qui est nécessaire est juste un moyen simple de faire l'arrêt de lavalamp au stade actuel où les enfants de <li>
sont plané puis retournent à travailler normalement après. Voici le code complet de plug-in pour référence!
(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);`
Merci d'avance.
La solution
le correctif pour cela est de changer le vol stationnaire () dans le lavalamp à mouseover comme indiqué sur la page suivante ..
Autres conseils
J'ajouté classe supplémentaire à haut niveau li et mis à jour les js:
$li = $("li.top-level-item", this),