1

私はある種のばかげたウェブサイトのリクエストを持っています-彼らはホバー状態がアニメーション化することを望んでいます。

とにかく...作成しようとしている効果を示すためにスライドショーを作成しましたが、jQueryコードで機能させることができません。私はここで答えだと思ったものを見つけました:CSSクラス/ホバー状態の間でループしようとしています-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;
    });
    });

どんな助けでも大歓迎です!さらに情報が必要な場合はお知らせください。ハイクキティ

4

2 に答える 2

1

AFAIKには、JSでCSSホバー状態をシミュレートする方法はありません。ただし、単純なjQueryソリューションが必要な場合は、これで必要な処理を実行できます(fiddle)。

CSS(:hover pseudo-classを使用)

#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;
    });
});​
于 2012-12-16T23:03:24.633 に答える
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');
});
于 2012-12-16T23:31:47.860 に答える