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.

Était-ce utile?

La solution

le correctif pour cela est de changer le vol stationnaire () dans le lavalamp à mouseover comme indiqué sur la page suivante ..

http://hekimian-williams.com/?p=146

Autres conseils

J'ajouté classe supplémentaire à haut niveau li et mis à jour les js:

$li = $("li.top-level-item", this),
Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top