在悬停状态之间循环

时间:2012-12-16 22:36:02

标签: jquery html css3

我有一个愚蠢的网站请求 - 他们希望悬停状态动画,因为他们认为没有人会知道那里有链接...

无论如何......我创建了一个幻灯片,以显示我正在尝试创建的效果 - 但现在我无法使用jQuery代码。我在这里找到了我认为的答案:Trying to loop between CSS classes/hover states - Jquery

但即使合并了这个新代码,动画/切换也无效。

我认为我错过了一些明显的东西 - 有人可以帮忙吗?

这是幻灯片版本,以显示我想要的效果: http://test.fatcat-studios.com/gtm/index.html 但我想用jQuery做到这一点,所以当你与它进行交互时,正确的悬停状态显示在实际鼠标悬停时。

这是我的jQuery代码:

    $(function() {
    var doToggle = true;                            
    $('a.res').removeClass('hover');
    $('a.com').addClass('hover');                           
    var tid = setInterval( function() {
    if (doToggle) $('a.res, a.com').toggleClass('hover');
    }, 2000);

    setTimeout(function() {

    if (tid) clearInterval(tid);

    $('a.res,a.com').removeClass('hover');
    }, 30000); // stop toggling after 30 seconds

    $('a.res,a.com').hover( function() {
    doToggle = false;
    }, function() {
    doToggle = true;
    });
    });

非常感谢任何帮助!如果需要更多信息,请告诉我。 Haikukitty

2 个答案:

答案 0 :(得分:1)

AFAIK无法用JS模拟CSS悬停状态。但是,如果你想要一个简单的jQuery解决方案,这应该做你想要的(fiddle)。

CSS(使用:hover伪类)

#clicky {
    color:#000;
}

#clicky:hover {
    color:#FFBF00;
}

JS

yep = true; // just a global var to stop it flashing when the user hovers
// you may want to persist this differently

$(function() {
    setInterval(function() {
        if (yep) {
            var $c = $('#clicky');
            $c.css({color: $c.hasClass('active') ? '#000' : '#FFBF00'}).toggleClass('active');
        }
    }, 1 * 1000);

    $('#clicky').hover(function() {
        yep = false;
    }, function() {
        yep = true;
    });
});​

答案 1 :(得分:1)

试试这个:

$(function() {
    var autoToggle = true;
    var $togglers = $('a.res, a.com');

    var tid_1,
        tid_2 = setTimeout(function() {
        clearInterval(tid_1);
        $togglers.removeClass('hover');
        autoToggle = false;
    }, 30000); // stop toggling after 30 seconds

    $togglers.hover(function() {
        clearInterval(tid_1);
        $togglers.removeClass('hover');
        $(this).addClass('hover');
    }, function() {
        if(autoToggle) {
            $('a.res').removeClass('hover');
            $('a.com').addClass('hover');
            tid_1 = setInterval(function() {
                $togglers.toggleClass('hover');
            }, 2000);
        }
        else {
            $togglers.removeClass('hover');
        }
    }).triggerHandler('mouseout');
});