如果鼠标停留超过2秒然后显示其他没有?

时间:2012-06-29 14:27:44

标签: jquery html css3 timer slidedown

这是我在悬停时应用于div的jQuery幻灯片功能,以便向下滑动按钮。

它工作正常,但现在每当有人进出它时,它就会一直上下跳动。

我想如果我把一个或两个延迟计时器放在它上面会更有意义。

如果用户在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>

2 个答案:

答案 0 :(得分:59)

您需要在鼠标悬停时设置计时器并在幻灯片激活时或鼠标悬停时清除它,以先发生者为准:

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');
    }
});

See it in action.

答案 1 :(得分: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);
});