31

これは、ボタンを下にスライドさせるためにホバーのdivに適用したjQueryスライド関数です。

誰かが出入りするたびに上下に揺れ続けることを除けば、問題なく動作します。

1秒か2秒の遅延タイマーをかけるともっと理にかなっていると思いました。

ユーザーが1〜2秒以上divにいる場合にのみ、スライドを下に実行するように関数を変更するにはどうすればよいですか?

<script type="text/javascript" src="http://code.jquery.com/jquery-latest.min.js "></script>
<script type="text/javascript">

$("#NewsStrip").hover(
function () {
    $("#SeeAllEvents").slideDown('slow');    },
function () {
    $("#SeeAllEvents").slideUp('slow');
});

</script>
4

2 に答える 2

67

マウスオーバー時にタイマーを設定し、スライドがアクティブ化されたときまたはマウスアウト時にタイマーをクリアする必要があります。

var timeoutId;
$("#NewsStrip").hover(function() {
    if (!timeoutId) {
        timeoutId = window.setTimeout(function() {
            timeoutId = null; // EDIT: added this line
            $("#SeeAllEvents").slideDown('slow');
       }, 2000);
    }
},
function () {
    if (timeoutId) {
        window.clearTimeout(timeoutId);
        timeoutId = null;
    }
    else {
       $("#SeeAllEvents").slideUp('slow');
    }
});

実際の動作をご覧ください。

于 2012-06-29T14:34:41.430 に答える
4
var time_id;

$("#NewsStrip").hover(
function () {
    if (time_id) {
        clearTimeout(time_id);
    } 
    time_id = setTimeout(function () {
        $("#SeeAllEvents").stop(true, true).slideDown('slow');
    }, 2000);
}, function () {
    if (time_id) {
        clearTimeout(time_id);
    } 
    time_id = setTimeout(function () {
        $("#SeeAllEvents").stop(true, true).slideUp('slow');
    }, 2000);
});
于 2012-06-29T14:32:55.517 に答える